ViewTube_GM

Watch videos from video sharing websites without Flash Player.

  1. // ==UserScript==
  2. // @name ViewTube_GM
  3. // @version 2017.05.27
  4. // @description Watch videos from video sharing websites without Flash Player.
  5. // @author trupf
  6. // @namespace https://userscripts.org/users/trupf
  7. // @__icon http://s3.amazonaws.com/uso_ss/icon/87011/large.png
  8. // @icon https://raw.githubusercontent.com/sebaro/viewtube/master/viewtube.png
  9. // @require https://cdnjs.cloudflare.com/ajax/libs/hls.js/0.6.1/hls.min.js
  10. // @require https://cdnjs.cloudflare.com/ajax/libs/shaka-player/1.6.5/shaka-player.compiled.js
  11. // @_require http://dashif.org/reference/players/javascript/v1.6.0/dist/dash.all.js
  12. // @_require http://dashif.org/reference/players/javascript/v2.0.0/dist/dash.all.min.js
  13. // @include http://youtube.com*
  14. // @include http://www.youtube.com*
  15. // @include https://youtube.com*
  16. // @include https://www.youtube.com*
  17. // @include http://gaming.youtube.com*
  18. // @include https://gaming.youtube.com*
  19. // @include http://dailymotion.com*
  20. // @include http://www.dailymotion.com*
  21. // @include https://dailymotion.com*
  22. // @include https://www.dailymotion.com*
  23. // @include http://vimeo.com*
  24. // @include http://www.vimeo.com*
  25. // @include https://vimeo.com*
  26. // @include https://www.vimeo.com*
  27. // @include http://metacafe.com*
  28. // @include http://www.metacafe.com*
  29. // @include https://metacafe.com*
  30. // @include https://www.metacafe.com*
  31. // @include http://break.com*
  32. // @include http://www.break.com*
  33. // @include https://break.com*
  34. // @include https://www.break.com*
  35. // @include http://funnyordie.com*
  36. // @include http://www.funnyordie.com*
  37. // @include https://funnyordie.com*
  38. // @include https://www.funnyordie.com*
  39. // @include http://veoh.com*
  40. // @include http://www.veoh.com*
  41. // @include https://veoh.com*
  42. // @include https://www.veoh.com*
  43. // @include http://www.imdb.org/*
  44. // @include http://www.imdb.com/video*
  45. // @include https://www.imdb.com/video*
  46. // @include http://viki.com*
  47. // @include http://www.viki.com*
  48. // @include https://viki.com*
  49. // @include https://www.viki.com*
  50. // @include http://vevo.com*
  51. // @include http://www.vevo.com*
  52. // @include https://vevo.com*
  53. // @include https://www.vevo.com*
  54. // @include http://facebook.com*
  55. // @include http://www.facebook.com*
  56. // @include https://facebook.com*
  57. // @include https://www.facebook.com*
  58. // @include https://*/owncloud/apps/*
  59. // @include https://*/nextcloud/apps/*
  60. // @license GPLv3
  61. // @grant GM_xmlhttpRequest
  62. // @grant GM_setValue
  63. // @grant GM_getValue
  64. // @grant GM_log
  65. // @run-at document-end
  66.  
  67. // ==/UserScript==
  68.  
  69.  
  70. /*
  71.  
  72. Copyright (C) 2010 - 2014 Tobias Rupf
  73.  
  74. This program is free software: you can redistribute it and/or modify
  75. it under the terms of the GNU General Public License as published by
  76. the Free Software Foundation, either version 3 of the License, or
  77. (at your option) any later version.
  78.  
  79. This program is distributed in the hope that it will be useful,
  80. but WITHOUT ANY WARRANTY; without even the implied warranty of
  81. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  82. GNU General Public License for more details.
  83.  
  84. You should have received a copy of the GNU General Public License
  85. along with this program. If not, see <http://www.gnu.org/licenses/>.
  86.  
  87. This Program is mainly based on the work of Sebastian Luncan
  88. (Website: http://isebaro.com/viewtube)
  89.  
  90. Youtube Signature decryption and mutation observers by Gantt.
  91. (see http://userscripts.org/scripts/show/25105)
  92.  
  93. */
  94.  
  95. (function() {
  96.  
  97. // ==========Variables========== //
  98.  
  99. // Userscript
  100. var userscript = 'ViewTube_GM';
  101.  
  102. // Page
  103. var page = {win: window, doc: document, body: document.body, url: window.location.href};
  104. var videoDiv,videoLink;
  105. var dashplayer;
  106.  
  107. // Player
  108. //var player = {};
  109. var myPlayerWindow, HeadWindow, OrgPlayerIndex;
  110. var feature = {'autoplay': true, 'definition': true, 'container': true, 'dash': false, 'direct': false, 'widesize': true, 'fullsize': true};
  111. var plugins = ['HTML5'];
  112. if ((navigator.appVersion.indexOf('Chrome/') == -1) || (parseInt(navigator.appVersion.substr(navigator.appVersion.indexOf('Chrome/')+7,2)) < 35)
  113. || ((navigator.platform.indexOf('Win') != -1) && (parseInt(navigator.appVersion.substr(navigator.appVersion.indexOf('Chrome/')+7,2)) < 45))) {
  114. plugins = ['Auto'].concat(plugins);
  115. plugins = plugins.concat(['MPEG', 'MP4', 'FLV', 'VLC']);
  116. if (navigator.platform.indexOf('Win') != -1) plugins = plugins.concat(['WMP', 'WMP2', 'QT']);
  117. else if (navigator.platform.indexOf('Mac') != -1) plugins = plugins.concat(['QT']);
  118. else plugins = plugins.concat(['Totem', 'Xine']);
  119. }
  120. var option = {'plugin': plugins[0], 'autoplay': false, 'autoget': false, 'definition': 'HD', 'container': 'MP4', 'widesize': false, 'fullsize': false};
  121. var mimetypes = {
  122. 'MPEG': 'video/mpeg',
  123. 'MP4': 'video/mp4',
  124. 'HLS': 'video/mp4',
  125. 'WebM': 'video/webm',
  126. 'FLV': 'video/x-flv',
  127. 'MOV': 'video/quicktime',
  128. 'M4V': 'video/x-m4v',
  129. 'AVI': 'video/x-msvideo',
  130. '3GP': 'video/3gpp',
  131. 'WMP': 'application/x-ms-wmp',
  132. 'WMP2': 'application/x-mplayer2',
  133. 'QT': 'video/quicktime',
  134. 'VLC': 'application/x-vlc-plugin',
  135. 'Totem': 'application/x-totem-plugin',
  136. 'Xine': 'application/x-xine-plugin'
  137. };
  138.  
  139. // Links
  140. var website = 'https://gf.qytechs.cn/de/scripts/1203-viewtube-gm';
  141. var contact = 'https://gf.qytechs.cn/de/scripts/1203-viewtube-gm/feedback';
  142.  
  143. // ==========Fixes========== //
  144.  
  145. // Don't run on frames or iframes
  146. //if ((page.url.indexOf('imdb.com/') == -1) && (window.top != window.self)) return;
  147.  
  148.  
  149. // ==========Functions========== //
  150.  
  151. function createVideoElement (type, content, player) {
  152. function createPlayerElement (type, content, player) {
  153. player['contentVideo'] = createMyElement (type, content,'','','',player);
  154. player['contentVideo'].width = player['contentWidth'];
  155. player['contentVideo'].height = player['contentHeight'];
  156. styleMyElement (player['contentVideo'], {position: 'relative', width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px'});
  157. modifyMyElement (player['playerContent'], 'div', '', true);
  158. appendMyElement (player['playerContent'], player['contentVideo']);
  159. }
  160. setTimeout(function() { createPlayerElement(type, content, player); }, 0);
  161. }
  162.  
  163. function passwdDialog (player) {
  164. playMyVideo (player, false);
  165. modifyMyElement (player['playerContent'], 'div', '', true);
  166. styleMyElement (player['playerContent'], {backgroundColor: '#F4F4F4',})
  167. /* Login Data */
  168. var myLoginWindowUser = createMyElement ('div', 'Username: <input type="text" name="user" id="user" placeholder="username" value="'+player['user']+'" autofocus="" autocomplete="on" autocapitalize="off" autocorrect="off" required="" original-title=""> <label for="user" class="infield">Benutzername</label>', '', '', '');
  169. styleMyElement (myLoginWindowUser, {position: 'relative', backgroundColor: '#F4F4F4', margin: '5px', marginLeft: '5px !important',width: '200px !important', textAlign: 'left'});
  170. appendMyElement (player['playerContent'], myLoginWindowUser);
  171. var myLoginWindowPass = createMyElement ('div', 'Password: <input type="password" name="password" id="password" value="'+player['passwd']+'" placeholder="password" autocomplete="on" autocapitalize="off" autocorrect="off" required="" original-title=""> <label for="password" class="infield">Passwort</label>', '', '', '');
  172. styleMyElement (myLoginWindowPass, {position: 'relative', backgroundColor: '#F4F4F4', margin: '5px', marginLeft: '5px !important',width: '200px !important', textAlign: 'left'});
  173. appendMyElement (player['playerContent'], myLoginWindowPass);
  174. var submitButton = createMyElement ('div', '<input type="submit" id="submit" class="login primary" value="Submit" original-title="">', '', '', '');
  175. styleMyElement (submitButton, {display: 'inline', color: '#336699', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  176. appendMyElement (myLoginWindowPass, submitButton);
  177.  
  178. submitButton.addEventListener ('click', function () {
  179. player['user'] = document.getElementById("user").value;
  180. player['passwd'] = document.getElementById("password").value;
  181. setMyOptions('user',player['user']);
  182. setMyOptions('passwd',player['passwd']);
  183. removeMyElement (player['playerContent'], myLoginWindowPass);
  184. removeMyElement (player['playerContent'], myLoginWindowUser);
  185. styleMyElement (player['playerContent'], {backgroundColor: '#000000',});
  186. playMyVideo (player, false);
  187. }, false);
  188. }
  189.  
  190. function createMyElement (type, content, event, action, target, player) {
  191. var obj = page.doc.createElement(type);
  192. if (content) {
  193. if (type == 'div') obj.innerHTML = content;
  194. else if (type == 'img') obj.src = content;
  195. else if (type == 'option') {
  196. obj.value = content;
  197. obj.innerHTML = content;
  198. }
  199. else if (type == 'video') {
  200. // username + password is for HTML5 playback not required again, ==> only for testing
  201. /*
  202. var urlSplit = content.split('://');
  203. if (!player['user']) var url = content;
  204. else if (!player['passwd']) var url = urlSplit[0] + '://' + player['user'] + '@' + urlSplit[1];
  205. else var url = urlSplit[0] + '://' + player['user'] + ':' + player['passwd'] +'@' + urlSplit[1]; */
  206. obj.id = 'vtVideo';
  207. obj.controls = 'true';
  208. obj.preload = 'auto';
  209. obj.autoplay = 'autoplay';
  210. obj.volume = 0.5;
  211. 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>.';
  212. if (player.videoPlay.indexOf('DASH MP4') != -1) {
  213. // Install built-in polyfills to patch browser incompatibilities.
  214. shaka.polyfill.installAll();
  215. // Check to see if the browser supports the basic APIs Shaka needs.
  216. shaka.Player.support().then(function(support) {
  217. if (support.supported) {
  218. function onErrorEvent(event) {onError(event.detail);};
  219. function onError(error) {console.error(error); console.log('Error code ' + error.code);}
  220. var myPlayer = new shaka.Player(obj);
  221. myPlayer.addEventListener('error', onErrorEvent);
  222. // Try to load a manifest.
  223. myPlayer.load(content).then(function(){}).catch(onError);
  224. } else {
  225. console.log('Browser does not support DASH!');
  226. }
  227. });
  228. }
  229. else if (player.videoPlay.indexOf('HLS') != -1 || player.videoPlay.indexOf('HTTP Live Streaming') != -1 || content.indexOf('.m3u8') != -1) {
  230. if (typeof Hls == 'function' && Hls.isSupported()) {
  231. var hls_error_counter = 0;
  232. var hls = new Hls();
  233. hls.on(Hls.Events.MANIFEST_PARSED,function(event, data) {
  234. obj.play();
  235. });
  236. hls.loadSource(content);
  237. hls.attachMedia(obj);
  238. }
  239. }
  240. else obj.src = content;
  241. }
  242. else if (type == 'object') {
  243. // external player may require username + password
  244. var urlSplit = content.split('://');
  245. if (!player['user']) obj.data = content;
  246. else if (!player['passwd']) obj.data = urlSplit[0] + '://' + player['user'] + '@' + urlSplit[1];
  247. else obj.data = urlSplit[0] + '://' + player['user'] + ':' + player['passwd'] +'@' + urlSplit[1];
  248. console.log(obj.data);
  249. obj.id = 'videoplayer';
  250. 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">';
  251. }
  252. else if (type == 'embed') {
  253. // external player may require username + password
  254. var urlSplit = content.split('://');
  255. if (!player['user']) var url = content;
  256. else if (!player['passwd']) var url = urlSplit[0] + '://' + player['user'] + '@' + urlSplit[1];
  257. else var url = urlSplit[0] + '://' + player['user'] + ':' + player['passwd'] +'@' + urlSplit[1];
  258. console.log(url);
  259. if (option['plugin'] == 'VLC') obj.setAttribute('target', url);
  260. else obj.src = url;
  261. obj.id = 'videoplayer';
  262. 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">';
  263. }
  264. }
  265. if (type == 'video' || type == 'object' || type == 'embed') {
  266. if (option['plugin'] == 'Auto' || option['plugin'] == 'Alt' || option['plugin'] == 'HTML5') {
  267. if (content == 'DASH') obj.type = 'application/dash+xml';
  268. else obj.type = mimetypes[player['videoPlay'].replace(/.*\s/, '')];
  269. }
  270. else {
  271. obj.type = mimetypes[option['plugin']];
  272. }
  273. obj.id = 'vtVideo';
  274. }
  275. if (event == 'change') {
  276. if (target == 'video') {
  277. obj.addEventListener ('change', function (e) {
  278. if (e.target) player['videoPlay'] = e.target.value;
  279. else if (e.srcElement) player['videoPlay'] = e.srcElement.value;
  280. if (player['isGetting']) {
  281. modifyMyElement (player['buttonGet'] , 'div', 'Get', false);
  282. player['isGetting'] = false;
  283. }
  284. if (player['isPlaying']) playMyVideo(player, option['autoplay']);
  285. }.bind(player), false);
  286. }
  287. else if (target == 'plugin') {
  288. obj.addEventListener ('change', function (e) {
  289. if (e.target) option['plugin'] = e.target.value;
  290. else if (e.srcElement) option['plugin'] = e.srcElement.value;
  291. setMyOptions ('viewtube_plugin', option['plugin']);
  292. if (player['isPlaying']) playMyVideo(player, true);
  293. }.bind(player), false);
  294. }
  295. }
  296. else if (event == 'click') {
  297. obj.addEventListener ('click', function () {
  298. if (action == 'close') {
  299. removeMyElement(page.body, target);
  300. }
  301. else if (action == 'logo') {
  302. page.win.location.href = website;
  303. }
  304. else if (action == 'play') {
  305. playMyVideo(player, !player['isPlaying']);
  306. }
  307. else if (action == 'get') {
  308. getMyVideo(player);
  309. }
  310. else if (action == 'autoplay') {
  311. option['autoplay'] = (option['autoplay']) ? false : true;
  312. if (option['autoplay']) {
  313. // styleMyElement (player['buttonPlay'], {display: 'none'});
  314. styleMyElement (player['buttonAutoplay'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
  315. if (!player['isPlaying']) playMyVideo(player, true);
  316. }
  317. else {
  318. // styleMyElement (player['buttonPlay'], {display: 'inline'});
  319. styleMyElement (player['buttonAutoplay'], {color: '#CCCCCC', textShadow: '0px 0px 0px'});
  320. playMyVideo(player, false);
  321. }
  322. setMyOptions ('viewtube_autoplay', option['autoplay']);
  323. }
  324. else if (action == 'definition') {
  325. for (var itemDef = 0; itemDef < option['definitions'].length; itemDef++) {
  326. if (option['definitions'][itemDef].match(/[A-Z]/g).join('') == option['definition']) {
  327. var nextDef = (itemDef + 1 < option['definitions'].length) ? itemDef + 1 : 0;
  328. option['definition'] = option['definitions'][nextDef].match(/[A-Z]/g).join('');
  329. break;
  330. }
  331. }
  332. modifyMyElement (player['buttonDefinition'], 'div', option['definition'], false);
  333. setMyOptions ('viewtube_definition', option['definition']);
  334. if (player['isGetting']) {
  335. modifyMyElement (player['buttonGet'] , 'div', 'Get', false);
  336. player['isGetting'] = false;
  337. }
  338. selectMyVideo (player);
  339. if (player['isPlaying']) playMyVideo(player, true);
  340. }
  341. else if (action == 'container') {
  342. for (var itemCont = 0; itemCont < option['containers'].length; itemCont++) {
  343. if (option['containers'][itemCont] == option['container']) {
  344. var nextCont = (itemCont + 1 < option['containers'].length) ? itemCont + 1 : 0;
  345. option['container'] = option['containers'][nextCont];
  346. break;
  347. }
  348. }
  349. modifyMyElement (player['buttonContainer'], 'div', option['container'], false);
  350. setMyOptions ('viewtube_container', option['container']);
  351. if (player['isGetting']) {
  352. modifyMyElement (player['buttonGet'] , 'div', 'Get', false);
  353. player['isGetting'] = false;
  354. }
  355. selectMyVideo (player);
  356. if (player['isPlaying']) playMyVideo(player, true);
  357. }
  358. else if (action == 'widesize') {
  359. option['widesize'] = (option['widesize']) ? false : true;
  360. setMyOptions ('viewtube_widesize', option['widesize']);
  361. resizeMyPlayer(player, 'widesize');
  362. }
  363. else if (action == 'fullsize') {
  364. option['fullsize'] = (option['fullsize']) ? false : true;
  365. resizeMyPlayer(player, 'fullsize');
  366. }
  367. else if (action == 'PWdialog') {
  368. passwdDialog (player);
  369. }
  370. }.bind(player), false);
  371. }
  372. return obj;
  373. }
  374.  
  375. function getMyElement (obj, type, from, value, child, content) {
  376. var getObj, chObj, coObj;
  377. var pObj = (!obj) ? page.doc : obj;
  378. if (type == 'body') getObj = pObj.body;
  379. else {
  380. if (from == 'id') getObj = pObj.getElementById(value);
  381. else if (from == 'class') getObj = pObj.getElementsByClassName(value);
  382. else if (from == 'tag') getObj = pObj.getElementsByTagName(type);
  383. else if (from == 'ns') getObj = pObj.getElementsByTagNameNS(value, type);
  384. }
  385. chObj = (child >= 0) ? getObj[child] : getObj;
  386. if (content && chObj) {
  387. if (type == 'html' || type == 'body' || type == 'div' || type == 'option') coObj = chObj.innerHTML;
  388. else if (type == 'object') coObj = chObj.data;
  389. else if (type == 'img' || type == 'video' || type == 'embed') coObj = chObj.src;
  390. else coObj = chObj.textContent;
  391. return coObj;
  392. }
  393. else {
  394. return chObj;
  395. }
  396. }
  397.  
  398. function modifyMyElement (obj, type, content, clear, hide) {
  399. if (content) {
  400. if (type == 'div') obj.innerHTML = content;
  401. else if (type == 'option') {
  402. obj.value = content;
  403. obj.innerHTML = content;
  404. }
  405. else if (type == 'object') obj.data = content;
  406. else if (type == 'img' || type == 'video' || type == 'embed') obj.src = content;
  407. }
  408. if (clear) {
  409. if (obj.hasChildNodes()) {
  410. while (obj.childNodes.length >= 1) {
  411. obj.removeChild(obj.firstChild);
  412. }
  413. }
  414. }
  415. if (hide) {
  416. for(var i = 0; i < obj.children.length; i++) {
  417. styleMyElement(obj.children[i], {display: 'none'});
  418. }
  419. }
  420. }
  421.  
  422. function cleanMyElement (element, hide) {
  423. var elEmbed, elVideo;
  424. if (hide) styleMyElement (element, {display: 'none'});
  425. elEmbed = getMyElement (element, 'embed', 'tag', '', 0, false) || getMyElement (element, 'object', 'tag', '', 0, false);
  426. if (elEmbed && elEmbed.parentNode) {
  427. removeMyElement (elEmbed.parentNode, elEmbed);
  428. if (!hide) return;
  429. }
  430. elVideo = getMyElement (element, 'video', 'tag', '', 0, false);
  431. if (elVideo && elVideo.src && elVideo.currentSrc) {
  432. modifyMyElement (elVideo, 'video', 'none', true);
  433. if (!hide && elVideo.parentNode) removeMyElement (elVideo.parentNode, elVideo);
  434. if (elVideo.parentNode) try {elVideo.pause()} catch(e) {};
  435. }
  436. var elWait = 50;
  437. var elRemove = page.win.setInterval (function () {
  438. if (!elVideo) {
  439. elVideo = getMyElement (element, 'video', 'tag', '', 0, false);
  440. if (!elVideo) {
  441. elEmbed = getMyElement (element, 'embed', 'tag', '', 0, false) || getMyElement (element, 'object', 'tag', '', 0, false);
  442. if (elEmbed && elEmbed.id != 'vtVideo' && elEmbed.parentNode) {
  443. removeMyElement (elEmbed.parentNode, elEmbed);
  444. page.win.clearInterval (elRemove);
  445. }
  446. }
  447. }
  448. if (elVideo && elVideo.id != 'vtVideo' && elVideo.currentSrc && elVideo.currentSrc.indexOf('none') == -1) {
  449. modifyMyElement (elVideo, 'video', 'none', true);
  450. if (elVideo.parentNode) try {elVideo.pause()} catch(e) {};
  451. if (!hide && elVideo.parentNode) removeMyElement (elVideo.parentNode, elVideo);
  452. }
  453. if (elWait > 0) elWait--;
  454. else page.win.clearInterval (elRemove);
  455. }, 500);
  456. }
  457.  
  458. function styleMyElement (obj, styles) {
  459. for (var property in styles) {
  460. if (styles.hasOwnProperty(property)) obj.style[property] = styles[property];
  461. }
  462. }
  463.  
  464. function appendMyElement (parent, child) {
  465. parent.appendChild(child);
  466. }
  467.  
  468. function removeMyElement (parent, child) {
  469. parent.removeChild(child);
  470. }
  471.  
  472. function replaceMyElement (parent, orphan, child) {
  473. parent.replaceChild(orphan, child);
  474. }
  475.  
  476. function createHiddenElem(tag, id) {
  477. var elem=document.createElement(tag);
  478. elem.setAttribute('id', id);
  479. elem.setAttribute('style', 'display:none;');
  480. page.doc.body.appendChild(elem);
  481. return elem;
  482. }
  483.  
  484. function injectScript(code) {
  485. var script=document.createElement('script');
  486. script.type='application/javascript';
  487. script.textContent=code;
  488. page.doc.body.appendChild(script);
  489. page.doc.body.removeChild(script);
  490. }
  491.  
  492. function createMyPlayer (player) {
  493. /* Get My Options */
  494. getMyOptions ();
  495.  
  496. /* Player Settings */
  497. if (!player['panelHeight']) player['panelHeight'] = 18;
  498. if (!player['panelPadding']) player['panelPadding'] = 2;
  499.  
  500. /* The Panel */
  501. var panelWidth = player['playerWidth'] - player['panelPadding'] * 2;
  502. player['playerPanel'] = createMyElement ('div', '', '', '', '', player);
  503. styleMyElement(player['playerPanel'], {width: panelWidth + 'px', height: player['panelHeight'] + 'px', padding: player['panelPadding'] + 'px', backgroundColor: 'inherit', textAlign: 'center'});
  504. appendMyElement (player['playerWindow'], player['playerPanel']);
  505.  
  506. /* Panel Items */
  507. var panelItemBorder = 1;
  508. var panelItemHeight = player['panelHeight'] - panelItemBorder * 2;
  509. /* Panel Logo */
  510. player['panelLogo'] = createMyElement ('div', userscript + ':', 'click', 'logo', '', player);
  511. player['panelLogo'].title = 'ViewTube: click to visit the script web page';
  512. styleMyElement (player['panelLogo'], {height: panelItemHeight + 'px', border: '1px solid #F4F4F4', borderRadius: '3px', padding: '0px', display: 'inline', color: '#336699', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  513. appendMyElement (player['playerPanel'], player['panelLogo']);
  514.  
  515. /* Panel Video Menu */
  516. player['videoMenu'] = createMyElement ('select', '', 'change', '', 'video', player);
  517. player['videoMenu'].title = 'Videos: select the video format for playback';
  518. 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'});
  519. appendMyElement (player['playerPanel'], player['videoMenu'] );
  520. for (var videoCode in player['videoList']) {
  521. player['videoItem'] = createMyElement ('option', videoCode, '', '', '', player);
  522. styleMyElement(player['videoItem'], {padding: '0px', display: 'block', backgroundColor: '#F4F4F4', color: '#336699', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', cursor: 'pointer'});
  523. appendMyElement (player['videoMenu'], player['videoItem']);
  524. }
  525.  
  526. /* Panel Plugin Menu */
  527. player['pluginMenu'] = createMyElement ('select', '', 'change', '', 'plugin', player);
  528. player['pluginMenu'].title = 'Plugins: select the video plugin for playback';
  529. styleMyElement(player['pluginMenu'], {width: '70px', height: panelItemHeight + 'px', border: '1px solid transparent', borderRadius: '3px', padding: '0px', display: 'inline', backgroundColor: 'inherit', color: '#336699', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  530. appendMyElement (player['playerPanel'], player['pluginMenu'] );
  531. for (var p = 0; p < plugins.length; p++) {
  532. player['pluginItem'] = createMyElement ('option', plugins[p], '', '', '', player);
  533. styleMyElement (player['pluginItem'], {padding: '0px', display: 'block', backgroundColor: '#F4F4F4', color: '#336699', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  534. appendMyElement (player['pluginMenu'], player['pluginItem']);
  535. }
  536. player['pluginMenu'].value = option['plugin'];
  537.  
  538. /* Panel Play Button */
  539. player['buttonPlay'] = createMyElement ('div', 'Play', 'click', 'play', '', player);
  540. player['buttonPlay'].title = 'Play/Stop: click to start/stop video playback';
  541. styleMyElement(player['buttonPlay'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 3px', display: 'inline', color: '#37B704', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  542. // if (option['autoplay']) styleMyElement (player['buttonPlay'], {display: 'none'});
  543. appendMyElement (player['playerPanel'], player['buttonPlay']);
  544.  
  545. /* Panel Get Button */
  546. player['buttonGet'] = createMyElement ('div', 'Get', 'click', 'get', '', player);
  547. player['buttonGet'].title = 'Get: click to download the selected video format';
  548. styleMyElement(player['buttonGet'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C000C0', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  549. appendMyElement (player['playerPanel'], player['buttonGet']);
  550.  
  551. /* Panel Autoplay Button */
  552. if (feature['autoplay']) {
  553. player['buttonAutoplay'] = createMyElement ('div', 'AP', 'click', 'autoplay', '', player);
  554. player['buttonAutoplay'].title = 'Autoplay: click to enable/disable auto playback on page load';
  555. styleMyElement(player['buttonAutoplay'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#CCCCCC', fontSize: '12px', fontWeight: 'initial', verticalAlign: 'baseline', cursor: 'pointer'});
  556. if (option['autoplay']) styleMyElement (player['buttonAutoplay'], {color: '#008080', textShadow: '0px 1px 1px #CCCCCC'});
  557. appendMyElement (player['playerPanel'], player['buttonAutoplay']);
  558. }
  559.  
  560. /* Panel Definition Button */
  561. if (feature['definition']) {
  562. player['buttonDefinition'] = createMyElement ('div', option['definition'], 'click', 'definition', '', player);
  563. player['buttonDefinition'].title = 'Definition: click to change the preferred video definition';
  564. styleMyElement(player['buttonDefinition'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#008000', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  565. appendMyElement (player['playerPanel'], player['buttonDefinition']);
  566. }
  567.  
  568. /* Panel Container Button */
  569. if (feature['container']) {
  570. player['buttonContainer'] = createMyElement ('div', option['container'], 'click', 'container', '', player);
  571. player['buttonContainer'].title = 'Container: click to change the preferred video container';
  572. styleMyElement(player['buttonContainer'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#008000', fontSize: '12px', fontWeight: 'initial', textShadow: '0px 1px 1px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  573. appendMyElement (player['playerPanel'], player['buttonContainer']);
  574. }
  575.  
  576. /* Panel Widesize Button */
  577. if (feature['widesize']) {
  578. if (option['widesize']) player['buttonWidesize'] = createMyElement ('div', '&lt;', 'click', 'widesize', '', player);
  579. else player['buttonWidesize'] = createMyElement ('div', '&gt;', 'click', 'widesize', '', player);
  580. player['buttonWidesize'].title = 'Widesize: click to enter player widesize or return to normal size';
  581. styleMyElement(player['buttonWidesize'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C05800', fontSize: '12px', fontWeight: 'initial', textShadow: '1px 1px 2px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  582. appendMyElement (player['playerPanel'], player['buttonWidesize']);
  583. }
  584.  
  585. /* Panel Fullsize Button */
  586. if (feature['fullsize']) {
  587. if (option['fullsize']) player['buttonFullsize'] = createMyElement ('div', '-', 'click', 'fullsize', '', player);
  588. else player['buttonFullsize'] = createMyElement ('div', '+', 'click', 'fullsize', '', player);
  589. player['buttonFullsize'].title = 'Fullsize: click to enter player fullsize or return to normal size';
  590. styleMyElement (player['buttonFullsize'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C05800', fontSize: '12px', fontWeight: 'initial', textShadow: '1px 1px 2px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  591. appendMyElement (player['playerPanel'], player['buttonFullsize']);
  592. }
  593.  
  594. /* Panel Password Button */
  595. if (feature['PWdialog']) {
  596. player['buttonPW'] = createMyElement ('div', 'PW', 'click', 'PWdialog', '', player);
  597. player['buttonPW'].title = 'Password: click to show password dialog';
  598. styleMyElement (player['buttonPW'], {height: panelItemHeight + 'px', border: '1px solid #CCCCCC', borderRadius: '3px', padding: '0px 5px', display: 'inline', color: '#C05800', fontSize: '12px', fontWeight: 'initial', textShadow: '1px 1px 2px #CCCCCC', verticalAlign: 'baseline', cursor: 'pointer'});
  599. appendMyElement (player['playerPanel'], player['buttonPW']);
  600. }
  601.  
  602. /* The Content */
  603. player['contentWidth'] = player['playerWidth'];
  604. if (player['panelHeight'] == 18) player['contentHeight'] = player['playerHeight'] - player['panelHeight'] - player['panelPadding'] * 2;
  605. else player['contentHeight'] = player['playerHeight'] - player['panelHeight'];
  606. player['playerContent'] = createMyElement ('div', '', '', '', '');
  607. styleMyElement(player['playerContent'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px', position: 'relative', color: '#AD0000', backgroundColor: '#000000', fontSize: '14px', fontWeight: 'bold', textAlign: 'center'});
  608. appendMyElement (player['playerWindow'], player['playerContent']);
  609.  
  610. /* The Video Thumbnail */
  611. if (player['videoThumb']) {
  612. player['contentImage'] = createMyElement ('img', player['videoThumb'], 'click', 'play', '', player);
  613. player['contentImage'].title = 'Click to start video playback';
  614. styleMyElement(player['contentImage'], {maxWidth: '100%', maxHeight: '100%', position: 'absolute', top: '0px', left: '0px', right: '0px', bottom: '0px', margin: 'auto', border: '0px', cursor: 'pointer'});
  615.  
  616. // make sure small thumbnails will fill up the content area
  617. player['contentImage'].addEventListener('load', function () {
  618. // if image is wider than content area, scale its width, otherwise its height
  619. if (this.width/this.height >= player['contentWidth']/player['contentHeight']) {
  620. this.style.width = '1920px';
  621. }
  622. else {
  623. this.style.height = '1080px';
  624. }
  625. });
  626. }
  627.  
  628. /* Disabled Features */
  629. if (!feature['autoplay']) option['autoplay'] = false;
  630. if (!feature['widesize']) option['widesize'] = false;
  631. if (!feature['fullsize']) option['fullsize'] = false;
  632.  
  633. /* Resize My Player */
  634. if (option['widesize']) resizeMyPlayer(player, 'widesize');
  635. if (option['fullsize']) resizeMyPlayer(player, 'fullsize');
  636.  
  637. /* Select My Video */
  638. if (feature['definition'] || feature['container']) selectMyVideo (player);
  639.  
  640. /* Play My Video */
  641. playMyVideo (player, option['autoplay']);
  642. }
  643.  
  644. function selectMyVideo (player) {
  645. var vdoCont = (option['container'] != 'Any') ? [option['container']] : option['containers'];
  646. var vdoDef = option['definitions'];
  647. var vdoList = {};
  648. for (var vC = 0; vC < vdoCont.length; vC++) {
  649. if (vdoCont[vC] != 'Any') {
  650. for (var vD = 0; vD < vdoDef.length; vD++) {
  651. var format = vdoDef[vD] + ' ' + vdoCont[vC];
  652. if (!vdoList[vdoDef[vD]]) {
  653. for (var vL in player['videoList']) {
  654. if (vL == format) {
  655. vdoList[vdoDef[vD]] = vL;
  656. break;
  657. }
  658. }
  659. }
  660. }
  661. }
  662. }
  663. if (option['definition'] == 'UHD') {
  664. if (vdoList['Ultra High Definition']) player['videoPlay'] = vdoList['Ultra High Definition'];
  665. else if (vdoList['Full High Definition']) player['videoPlay'] = vdoList['Full High Definition'];
  666. else if (vdoList['High Definition']) player['videoPlay'] = vdoList['High Definition'];
  667. else if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
  668. else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
  669. else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
  670. }
  671. else if (option['definition'] == 'FHD') {
  672. if (vdoList['Full High Definition']) player['videoPlay'] = vdoList['Full High Definition'];
  673. else if (vdoList['High Definition']) player['videoPlay'] = vdoList['High Definition'];
  674. else if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
  675. else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
  676. else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
  677. }
  678. else if (option['definition'] == 'HD') {
  679. if (vdoList['High Definition']) player['videoPlay'] = vdoList['High Definition'];
  680. else if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
  681. else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
  682. else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
  683. }
  684. else if (option['definition'] == 'SD') {
  685. if (vdoList['Standard Definition']) player['videoPlay'] = vdoList['Standard Definition'];
  686. else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
  687. else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
  688. }
  689. else if (option['definition'] == 'LD') {
  690. if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
  691. else if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
  692. }
  693. else if (option['definition'] == 'VLD') {
  694. if (vdoList['Very Low Definition']) player['videoPlay'] = vdoList['Very Low Definition'];
  695. else if (vdoList['Low Definition']) player['videoPlay'] = vdoList['Low Definition'];
  696. }
  697. player['videoMenu'].value = player['videoPlay'];
  698. }
  699.  
  700. function playMyVideo (player, play) {
  701. if (play) {
  702. player['isPlaying'] = true;
  703. modifyMyElement (player['buttonPlay'], 'div', 'Stop', false);
  704. styleMyElement (player['buttonPlay'], {color: '#AD0000'});
  705. if (option['plugin'] == 'HTML5') {
  706. /* if (player['videoPlay'] == 'DASH MP4') {
  707. player['contentVideo'] = createVideoElement ('video', 'DASH', player);
  708. }
  709. else */
  710. player['contentVideo'] = createVideoElement ('video', player['videoList'][player['videoPlay']], player);
  711. }
  712. else if (navigator.appName == 'Netscape') player['contentVideo'] = createVideoElement ('embed', player['videoList'][player['videoPlay']], player);
  713. else createVideoElement ('object', player['videoList'][player['videoPlay']], player);
  714. }
  715. else {
  716. player['isPlaying'] = false;
  717. modifyMyElement (player['buttonPlay'], 'div', 'Play', false);
  718. styleMyElement (player['buttonPlay'], {color: '#37B704'});
  719. modifyMyElement (player['playerContent'], 'div', '', true);
  720. if (player['videoDuration']) {
  721. var hours = Math.floor(player['videoDuration'] / 3600);
  722. var minutes = Math.floor((player['videoDuration'] % 3600) / 60);
  723. var seconds = (player['videoDuration'] % 3600) % 60;
  724. var duration = (hours > 0 ? (hours + ':' + (minutes > 9 ? minutes : '0' + minutes)) : minutes) + ':' + (seconds > 9 ? seconds : '0' + seconds);
  725. player['durationElem'] = createMyElement ('div',duration , '', '', '', player);
  726. styleMyElement (player['durationElem'], {position: 'absolute', backgroundColor: '#000000', color: '#FFFFFF', fontSize: '14px',fontWeight: 'bold', textAlign: 'right',
  727. right: '5px', bottom: '10px',paddingLeft: '2px', paddingRight: '2px', zIndex: '9'});
  728. appendMyElement (player['playerContent'], player['durationElem']);
  729. }
  730.  
  731. if (player['contentImage']) appendMyElement (player['playerContent'], player['contentImage']);
  732. else showMyMessage ('!thumb', '', player);
  733. }
  734. }
  735.  
  736. function getMyVideo (player) {
  737. var vdoURL = player['videoList'][player['videoPlay']];
  738. if (player['videoTitle']) {
  739. var vdoD = ' (' + player['videoPlay'] + ')';
  740. vdoD = vdoD.replace(/Ultra High Definition/, 'UHD');
  741. vdoD = vdoD.replace(/Full High Definition/, 'FHD');
  742. vdoD = vdoD.replace(/High Definition/, 'HD');
  743. vdoD = vdoD.replace(/Standard Definition/, 'SD');
  744. vdoD = vdoD.replace(/Very Low Definition/, 'VLD');
  745. vdoD = vdoD.replace(/Low Definition/, 'LD');
  746. vdoD = vdoD.replace(/\sFLV|\sMP4|\sWebM|\s3GP/g, '');
  747. vdoURL = vdoURL + '&title=' + player['videoTitle'] + vdoD;
  748. }
  749. if (option['autoget']) page.win.location.href = vdoURL;
  750. else {
  751. var vdoLink = 'Get <a href="' + vdoURL + '">Link</a>';
  752. modifyMyElement (player['buttonGet'] , 'div', vdoLink, false);
  753. player['isGetting'] = true;
  754. }
  755. }
  756.  
  757. function resizeMyPlayer (player, size) {
  758. if (size == 'widesize') {
  759. if (option['widesize']) {
  760. modifyMyElement (player['buttonWidesize'], 'div', '&lt;', false);
  761. var playerWidth = player['playerWideWidth'];
  762. var playerHeight = player['playerWideHeight'];
  763. var sidebarMargin = player['sidebarMarginWide'];
  764. var playlistMargin = player['playerWideHeight'];
  765. }
  766. else {
  767. modifyMyElement (player['buttonWidesize'], 'div', '&gt;', false);
  768. var playerWidth = player['playerWidth'];
  769. var playerHeight = player['playerHeight'];
  770. var sidebarMargin = player['sidebarMarginNormal'];
  771. var playlistMargin = 0;
  772. }
  773. }
  774. else if (size == 'fullsize') {
  775. if (option['fullsize']) {
  776. var playerPosition = 'fixed';
  777. var playerWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
  778. var playerHeight = page.win.innerHeight || page.doc.documentElement.clientHeight;
  779. var playerIndex = '2147483647';
  780. var frames = document.getElementsByTagName('iframe');
  781. for (var i = 0 ; i <frames.length; i++) styleMyElement(frames[i], {display: 'none'});
  782. setTimeout(function(){ if (option['fullsize']) {var frames = document.getElementsByTagName('iframe'); for (var i = 0 ; i <frames.length; i++) styleMyElement(frames[i], {display: 'none'});}},3000);
  783. if (!player['isFullsize']) {
  784. if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'none'});
  785. modifyMyElement (player['buttonFullsize'], 'div', '-', false);
  786. styleMyElement (page.body, {overflow: 'hidden'});
  787. styleMyElement (page.body.parentNode, {overflow: 'hidden'});
  788. if (!player['resizeListener']) player['resizeListener'] = function() {resizeMyPlayer(player, 'fullsize')};
  789. page.win.addEventListener ('resize', player['resizeListener'], false);
  790. OrgPlayerIndex = player['playerWindow'].style['zIndex'];
  791. OrgHeadWindowIndex = '';
  792. if (HeadWindow && HeadWindow.style) {
  793. styleMyElement(HeadWindow, {visibility: 'hidden'});
  794. }
  795. player['isFullsize'] = true;
  796. if (player['isPlaying']) {
  797. if (player['contentVideo'] && player['contentVideo'].paused) player['contentVideo'].play();
  798. }
  799. }
  800. }
  801. else {
  802. var playerPosition = 'relative';
  803. var playerWidth = (option['widesize']) ? player['playerWideWidth'] : player['playerWidth'];
  804. var playerHeight = (option['widesize']) ? player['playerWideHeight'] : player['playerHeight'];
  805. var playerIndex = OrgPlayerIndex;
  806. var frames = document.getElementsByTagName('iframe');
  807. for (var i = 0 ; i <frames.length; i++) styleMyElement(frames[i], {display: ''});
  808. if (feature['widesize']) styleMyElement (player['buttonWidesize'], {display: 'inline'});
  809. modifyMyElement (player['buttonFullsize'], 'div', '+', false);
  810. styleMyElement (page.body, {overflow: 'auto'});
  811. styleMyElement (page.body.parentNode, {overflow: 'auto'});
  812. page.win.removeEventListener ('resize', player['resizeListener'], false);
  813. if (HeadWindow && HeadWindow.style) styleMyElement(HeadWindow, {visibility: 'visible'});
  814. var frames = document.getElementsByTagName('iframe')
  815. for (var i = 0 ; i <frames.length; i++) {
  816. styleMyElement(frames[i], { display: ''});
  817. }
  818. player['isFullsize'] = false;
  819. if (player['isPlaying']) {
  820. if (player['contentVideo'] && player['contentVideo'].paused) player['contentVideo'].play();
  821. }
  822. }
  823. }
  824.  
  825. /* Resize The Player */
  826. if (size == 'widesize') {
  827. styleMyElement (player['sidebarWindow'], {marginTop: sidebarMargin + 'px'});
  828. // Playlist position fix for youtube
  829. var ytPlaylist = getMyElement ('', 'div', 'id', 'player-playlist', -1, false);
  830. if (ytPlaylist) styleMyElement (ytPlaylist, {top: playlistMargin + 'px'});
  831. styleMyElement (player['playerWindow'], {width: playerWidth + 'px', height: playerHeight + 'px'});
  832. }
  833. else {
  834. styleMyElement (player['playerWindow'], {position: playerPosition, top: '0px', left: '0px', width: playerWidth + 'px', height: playerHeight + 'px', zIndex: playerIndex});
  835. }
  836. /* Resize The Panel */
  837. var panelWidth = playerWidth - player['panelPadding'] * 2;
  838. styleMyElement (player['playerPanel'], {width: panelWidth + 'px'});
  839.  
  840. /* Resize The Content */
  841. player['contentWidth'] = playerWidth;
  842. if (player['panelHeight'] == 18) player['contentHeight'] = playerHeight - player['panelHeight'] - player['panelPadding'] * 2;
  843. else player['contentHeight'] = playerHeight - player['panelHeight'];
  844. styleMyElement (player['playerContent'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px'});
  845. if (player['isPlaying']) {
  846. player['contentVideo'].width = player['contentWidth'];
  847. player['contentVideo'].height = player['contentHeight'];
  848. styleMyElement (player['contentVideo'], {width: player['contentWidth'] + 'px', height: player['contentHeight'] + 'px'});
  849. }
  850. }
  851.  
  852. function cleanMyContent (content, unesc) {
  853. var myNewContent = content;
  854. if (!content) return myNewContent;
  855. if (unesc) myNewContent = unescape (myNewContent);
  856. myNewContent = myNewContent.replace (/\\u0025/g,'%');
  857. myNewContent = myNewContent.replace (/\\u0026/g,'&');
  858. myNewContent = myNewContent.replace (/\\/g,'');
  859. myNewContent = myNewContent.replace (/\n/g,'');
  860. return myNewContent;
  861. }
  862.  
  863. function getMyContent (url, pattern, clean) {
  864. var myPageContent, myVideosParse, myVideosContent;
  865. var isIE = (navigator.appName.indexOf('Internet Explorer') != -1) ? true : false;
  866. var getMethod = (url != page.url || isIE) ? 'XHR' : 'DOM';
  867. if (getMethod == 'DOM') {
  868. myPageContent = getMyElement ('', 'html', 'tag', '', 0, true);
  869. if (!myPageContent) myPageContent = getMyElement ('', 'body', '', '', -1, true);
  870. if (clean) myPageContent = cleanMyContent (myPageContent, true);
  871. myVideosParse = myPageContent.match (pattern);
  872. myVideosContent = (myVideosParse) ? myVideosParse[1] : null;
  873. if (myVideosContent) return myVideosContent;
  874. else getMethod = 'XHR';
  875. }
  876. if (getMethod == 'XHR') {
  877. var xmlHTTP = new XMLHttpRequest();
  878. xmlHTTP.open('GET', url, false);
  879. xmlHTTP.send();
  880. if (pattern == 'XML') {
  881. myVideosContent = xmlHTTP.responseXML;
  882. }
  883. else if (pattern == 'TEXT') {
  884. myVideosContent = xmlHTTP.responseText;
  885. }
  886. else {
  887. myPageContent = xmlHTTP.responseText;
  888. if (clean) myPageContent = cleanMyContent (myPageContent, true);
  889. myVideosParse = myPageContent.match (pattern);
  890. myVideosContent = (myVideosParse) ? myVideosParse[1] : null;
  891. }
  892. return myVideosContent;
  893. }
  894. }
  895.  
  896. function setMyOptions (key, value) {
  897. var key_extended = key + "_" + page.url.match(/https?:\/\/(www\.)?(.*?)\//)[2];
  898. if (typeof GM_setValue === 'function') {
  899. GM_setValue(key_extended, value);
  900. }
  901. else {
  902. try {
  903. localStorage.setItem(key_extended, value);
  904. }
  905. catch(e) {
  906. var date = new Date();
  907. date.setTime(date.getTime() + (356*24*60*60*1000));
  908. var expires = '; expires=' + date.toGMTString();
  909. page.doc.cookie = key_extended + '=' + value + expires + '; path=/';
  910. }
  911. }
  912. }
  913.  
  914. function getMyOption (key) {
  915. var key_extended = key + "_" + page.url.match(/https?:\/\/(www\.)?(.*?)\//)[2];
  916. if ((typeof GM_getValue === 'function') ){
  917. return GM_getValue(key_extended, null);
  918. }
  919. else
  920. try {
  921. return localStorage.setItem(key_extended);
  922. }
  923. catch(e) {
  924. var cookies = page.doc.cookie.split(';');
  925. for (var i=0; i < cookies.length; i++) {
  926. var cookie = cookies[i];
  927. while (cookie.charAt(0) == ' ') cookie = cookie.substring(1, cookie.length);
  928. if (cookie.indexOf(key) == 0) {
  929. return cookie.substring(key.length + 1, cookie.length);
  930. }
  931. }
  932. }
  933. }
  934.  
  935. function getMyOptions () {
  936. var tmpOption;
  937. tmpOption = getMyOption('viewtube_plugin');
  938. if (plugins.indexOf(tmpOption) == -1) tmpOption = plugins[0];
  939. option['plugin'] = tmpOption ? tmpOption : option['plugin'];
  940. option['autoplay'] = getMyOption('viewtube_autoplay');
  941. option['autoplay'] = (option['autoplay'] == 'true' || option['autoplay'] == true) ? true : false;
  942. tmpOption = getMyOption('viewtube_definition');
  943. option['definition'] = tmpOption ? tmpOption : option['definition'];
  944. tmpOption = getMyOption('viewtube_container');
  945. option['container'] = tmpOption ? tmpOption : option['container'];
  946. option['widesize'] = getMyOption('viewtube_widesize');
  947. option['widesize'] = (option['widesize'] == 'true' || option['widesize'] == true) ? true : false;
  948. option['fullsize'] = false;
  949. }
  950.  
  951. function showMyMessage (cause, content, player) {
  952. var myScriptLogo = createMyElement ('div', userscript, '', '', '');
  953. styleMyElement (myScriptLogo, {margin: '0px auto', padding: '10px', color: '#666666', fontSize: '24px', textAlign: 'center', textShadow: '#FFFFFF -1px -1px 2px'});
  954. var myScriptMess = createMyElement ('div', '', '', '', '');
  955. styleMyElement (myScriptMess, {border: '1px solid #F4F4F4', margin: '5px auto 5px auto', padding: '10px', backgroundColor: '#FFFFFF', color: '#AD0000', textAlign: 'center'});
  956. if (cause == '!player') {
  957. var myScriptAlert = createMyElement ('div', '', '', '', '');
  958. styleMyElement (myScriptAlert, {position: 'absolute', top: '30%', left: '35%', border: '1px solid #F4F4F4', borderRadius: '3px', padding: '10px', backgroundColor: '#F8F8F8', fontSize: '14px', textAlign: 'center', zIndex: '99999'});
  959. appendMyElement (myScriptAlert, myScriptLogo);
  960. var myNoPlayerMess = 'Couldn\'t get the player element. Please report it <a href="' + contact + '">here</a>.';
  961. modifyMyElement (myScriptMess, 'div', myNoPlayerMess, false);
  962. appendMyElement (myScriptAlert, myScriptMess);
  963. var myScriptAlertButton = createMyElement ('div', 'OK', 'click', 'close', myScriptAlert);
  964. 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'});
  965. appendMyElement (myScriptAlert, myScriptAlertButton);
  966. appendMyElement (page.body, myScriptAlert);
  967. }
  968. else if (cause == '!thumb') {
  969. var myNoThumbMess = '<br><br>Couldn\'t get the thumbnail for this video. Please report it <a href="' + contact + '">here</a>.';
  970. modifyMyElement (player['playerContent'], 'div', myNoThumbMess, false);
  971. }
  972. else {
  973. appendMyElement (myPlayerWindow, myScriptLogo);
  974. if (cause == '!content') {
  975. var myNoContentMess = 'Couldn\'t get the videos content. Please report it <a href="' + contact + '">here</a>.';
  976. modifyMyElement (myScriptMess, 'div', myNoContentMess, false);
  977. }
  978. else if (cause == '!videos') {
  979. var myNoVideosMess = 'Couldn\'t get any video. Please report it <a href="' + contact + '">here</a>.';
  980. modifyMyElement (myScriptMess, 'div', myNoVideosMess, false);
  981. }
  982. else if (cause == '!support') {
  983. var myNoSupportMess = 'This video uses the RTMP protocol and is not supported.';
  984. modifyMyElement (myScriptMess, 'div', myNoSupportMess, false);
  985. }
  986. else if (cause == 'embed') {
  987. var myEmbedMess = 'This is an embedded video. You can watch it <a href="' + content + '">here</a>.';
  988. modifyMyElement (myScriptMess, 'div', myEmbedMess, false);
  989. }
  990. else if (cause == 'other') {
  991. modifyMyElement (myScriptMess, 'div', content, false);
  992. }
  993. appendMyElement (myPlayerWindow, myScriptMess);
  994. }
  995. }
  996.  
  997. function crossXmlHttpRequest(details) { // cross-browser GM_xmlhttpRequest
  998. if (typeof GM_xmlhttpRequest === 'function') { // Greasemonkey, Tampermonkey, Firefox extension, Chrome script
  999. GM_xmlhttpRequest(details);
  1000. } else if (typeof window.opera !== 'undefined' && window.opera && typeof opera.extension !== 'undefined' &&
  1001. typeof opera.extension.postMessage !== 'undefined') { // Opera 12 extension
  1002. opera.extension.postMessage({'action':'xhr', 'url':details.url});
  1003. opera.extension.onmessage = function(event) {
  1004. if (event.data.action === 'xhr-response' && event.data.error === false) {
  1005. if (details['onload']) {
  1006. details['onload']({responseText:event.data.response, readyState:4, status:200});
  1007. }
  1008. }
  1009. }
  1010. } else if (typeof window.opera === 'undefined' && typeof XMLHttpRequest === 'function') { // Opera 15+ extension
  1011. var xhr=new XMLHttpRequest();
  1012. xhr.onreadystatechange = function() {
  1013. if (xhr.readyState == 4) {
  1014. if (details['onload'] && xhr.status >= 200 && xhr.status < 300) {
  1015. details['onload']({responseText:xhr.responseText, readyState:xhr.readyState, status:xhr.status});
  1016. }
  1017. }
  1018. }
  1019. xhr.open(details.method, details.url, true);
  1020. xhr.send();
  1021. }
  1022. }
  1023.  
  1024. function getMyContentGM(url, pattern, clean, callback) {
  1025. var myPageContent, myVideosParse, myVideosContent;
  1026. var isIE = (navigator.appName.indexOf('Internet Explorer') != -1) ? true : false;
  1027. var getMethod = (url != page.url || isIE) ? 'XHR' : 'DOM';
  1028. if (getMethod == 'DOM') {
  1029. myPageContent = getMyElement ('', 'html', 'tag', '', 0, true);
  1030. if (!myPageContent) myPageContent = getMyElement ('', 'body', '', '', -1, true);
  1031. if (clean) myPageContent = cleanMyContent (myPageContent, true);
  1032. myVideosParse = myPageContent.match (pattern);
  1033. myVideosContent = (myVideosParse) ? myVideosParse[1] : null;
  1034. if (myVideosContent) callback(myVideosContent);
  1035. else getMethod = 'XHR';
  1036. }
  1037. if (getMethod == 'XHR') {
  1038. crossXmlHttpRequest({
  1039. method: 'GET',
  1040. url: url,
  1041. onload: function(response) {
  1042. if (pattern == 'TEXT') {
  1043. myVideosContent = response.responseText;
  1044. }
  1045. else {
  1046. myPageContent = response.responseText;
  1047. if (clean) myPageContent = cleanMyContent (myPageContent, true);
  1048. myVideosParse = myPageContent.match (pattern);
  1049. myVideosContent = (myVideosParse) ? myVideosParse[1] : null;
  1050. }
  1051. callback(myVideosContent);
  1052. }
  1053. });
  1054. }
  1055. }
  1056.  
  1057.  
  1058. // ==========Websites========== //
  1059.  
  1060. // Fixes
  1061. var blockObject = page.doc;
  1062. var blockInterval = 50;
  1063.  
  1064. function blockVideos() {
  1065. var elVideos = getMyElement(blockObject, 'video', 'tag', '', -1, false);
  1066. if (elVideos.length > 0) {
  1067. for (var v = 0; v < elVideos.length; v++) {
  1068. var elVideo = elVideos[v];
  1069. if (elVideo && elVideo.id != 'vtVideo' && elVideo.currentSrc) {
  1070. if (!elVideo.paused) {
  1071. elVideo.pause();
  1072. if (page.url.indexOf('youtube.com/watch') == -1) elVideo.src = "#";
  1073. }
  1074. }
  1075. }
  1076. }
  1077. var elEmbeds = getMyElement(blockObject, 'embed', 'tag', '', -1, false) || getMyElement(blockObject, 'object', 'tag', '', -1, false);
  1078. if (elEmbeds.length > 0) {
  1079. for (var e = 0; e < elEmbeds.length; e++) {
  1080. var elEmbed = elEmbeds[e];
  1081. if (elEmbed && elEmbed.id != 'vtVideo' && elEmbed.parentNode) {
  1082. removeMyElement(elEmbed.parentNode, elEmbed);
  1083. }
  1084. }
  1085. }
  1086. if (blockObject !== page.doc) {
  1087. var elFrames = getMyElement(blockObject, 'iframe', 'tag', '', -1, false);
  1088. if (elFrames.length > 0) {
  1089. for (var e = 0; e < elFrames.length; e++) {
  1090. var elFrame = elFrames[e];
  1091. if (elFrame && elFrame.parentNode) {
  1092. removeMyElement(elFrame.parentNode, elFrame);
  1093. }
  1094. }
  1095. }
  1096. }
  1097. }
  1098. blockVideos();
  1099.  
  1100. page.win.setInterval(function() {
  1101. // Block videos
  1102. if (blockObject && blockInterval > 0) {
  1103. blockVideos();
  1104. if (blockInterval > 0) blockInterval--;
  1105. }
  1106. }, 300);
  1107.  
  1108. // =====YouTube===== //
  1109. /* Redirect Categories */
  1110. if (page.url.indexOf('gaming.youtube.com') != -1) {
  1111. page.win.location.href = page.url.replace('gaming', 'www');
  1112. }
  1113.  
  1114. else if (page.url.indexOf('www.youtube.com/') != -1) {
  1115. var decodeArray=[];
  1116. var searchstring;
  1117. ytPlayerResize = function () {return null;};
  1118.  
  1119. function findSignatureCode(ytScriptSrc) {
  1120. var arr=[];
  1121. ytScriptSrc = ytScriptSrc.replace(/(\r\n|\n|\r)/gm, '');
  1122. var functionName = ytScriptSrc.match(/"signature"\s*,\s*(.*?)\(/);
  1123. if (functionName == null) return;
  1124. functionName = functionName[1];
  1125. if (functionName.indexOf('$') === 0) functionName = "\\" + functionName;
  1126. var regCode = new RegExp('function '+functionName+'\\s*\\(\\w+\\)\\s*{\\w+=\\w+\\.split\\(""\\);(.+);return \\w+\\.join');
  1127. var functionCode = ytScriptSrc.match('function '+functionName+'\\s*\\(\\w+\\)\\s*{\\w+=\\w+\\.split\\(""\\);(.+);return \\w+\\.join');
  1128. if (!functionCode) functionCode = ytScriptSrc.match(functionName+'=function+\\s*\\(\\w+\\)\\s*{\\w+=\\w+\\.split\\(""\\);(.+?);return \\w+\\.join')
  1129. if (functionCode == null) return;
  1130. functionCode = functionCode[1];
  1131. var functionCodePieces = functionCode.split(';');
  1132. var decodevariable = functionCodePieces[0].match(/(\w+=)?(.*?)\./)[2];
  1133. if (decodevariable.indexOf('$') === 0) decodevariable = "\\" + decodevariable;
  1134. var decodefunctions = ytScriptSrc.match('var\\s+'+decodevariable+'=\\{.*?\\}\\}');
  1135. if (decodefunctions) {
  1136. var freverse = decodefunctions[0].match(decodevariable +'=.*(\\{|,)(.*?)\\:function.*?reverse\\(.*\\)\\}')[2];
  1137. var fslice = decodefunctions[0].match(decodevariable +'=.*(\\{|,)(.*?)\\:function.*?sp?lice\\(.*\\)\\}')[2];
  1138. var fswap = decodefunctions[0].match(decodevariable +'=.*(\\{|,)(.*?)\\:function.*?length];.*\\}')[2];
  1139. } else return;
  1140. for (var i=0; i<functionCodePieces.length; i++) {
  1141. functionCodePieces[i]=functionCodePieces[i].trim();
  1142. if (functionCodePieces[i].length>0)
  1143. if (functionCodePieces[i].indexOf(fslice) >= 0) { // slice
  1144. var slice=functionCodePieces[i].match(fslice+'\\s*\\(\\s*\\w*\\s*,(.+)\\s*\\)')[1];
  1145. slice=parseInt(slice, 10);
  1146. if (typeof slice === 'number') {
  1147. arr.push(-slice);
  1148. } else return;
  1149. } else if (functionCodePieces[i].indexOf(freverse) >= 0) {
  1150. arr.push(0);
  1151. } else if (functionCodePieces[i].indexOf(fswap) >= 0) {
  1152. var inline=functionCodePieces[i].match(fswap+'\\s*\\(\\s*\\w*\\s*,(.+)\\s*\\)')[1];
  1153. inline=parseInt(inline, 10);
  1154. if (typeof inline === 'number') {
  1155. arr.push(inline);
  1156. } else return;
  1157. } else if (functionCodePieces[i].indexOf(',') >= 0) {
  1158. var swap=functionCodePieces[i].match(regSwap)[1];
  1159. swap=parseInt(swap, 10);
  1160. if (typeof swap === 'number') {
  1161. arr.push(swap);
  1162. } else return;
  1163. } else return;
  1164. }
  1165. return arr;
  1166. }
  1167.  
  1168. function decryptSignature(sig) {
  1169. function swap(a,b){var c=a[0];a[0]=a[b%a.length];a[b]=c;return a};
  1170. function decode(sig, arr) { // encoded decryption
  1171. if (typeof sig !== 'string') return null;
  1172. var sigA=sig.split('');
  1173. for (var i=0;i<arr.length;i++) {
  1174. var act=parseInt(arr[i]);
  1175. if (typeof act !== 'number') return null;
  1176. sigA=(act>0)?swap(sigA, act):((act==0)?sigA.reverse():sigA.slice(-act));
  1177. }
  1178. return sigA.join('');
  1179. }
  1180. if (sig==null) return '';
  1181. if (decodeArray) {
  1182. var sig2=decode(sig, decodeArray);
  1183. if (sig2 && sig2.length == 81) return sig2;
  1184. }
  1185. return sig;
  1186. }
  1187.  
  1188. function yt_run(isMutation) {
  1189. /* Player Size */
  1190. var ytSidebarMarginNormal = 382;
  1191. var ytSidebarWindow = getMyElement ('', 'div', 'id', 'watch7-sidebar', -1, false);
  1192. if (!ytSidebarWindow) ytSidebarWindow = getMyElement ('', 'div', 'id', 'playlist', -1, false);
  1193. if (!ytSidebarWindow) ytSidebarWindow = getMyElement ('', 'div', 'id', 'related', -1, false);
  1194. if (ytSidebarWindow) var ytSidebarWindowStyle = ytSidebarWindow.currentStyle || window.getComputedStyle(ytSidebarWindow);
  1195. if (ytSidebarWindowStyle) {
  1196. ytSidebarMarginNormal = parseInt(ytSidebarWindowStyle.marginTop.replace('px', ''));
  1197. styleMyElement (ytSidebarWindow, {marginTop: ytSidebarMarginNormal + 'px'});
  1198. }
  1199. var ytPlayerWidth, ytPlayerHeight;
  1200. var ytPlayerWideWidth, ytPlayerWideHeight;
  1201. var ytSidebarMarginWide;
  1202. var ytScreenWidth, ytScreenHeight;
  1203.  
  1204. function ytSizes() {
  1205. ytScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
  1206. ytScreenHeight = page.win.innerHeight || page.doc.documentElement.clientHeight;
  1207. if (ytScreenWidth >= 1720 && ytScreenHeight >= 980) {
  1208. ytPlayerWidth = 1280;
  1209. ytPlayerHeight = 742;
  1210. ytPlayerWideWidth = 1706;
  1211. ytPlayerWideHeight = 982;
  1212. }
  1213. else if (ytScreenWidth >= 1294 && ytScreenHeight >= 630) {
  1214. ytPlayerWidth = 854;
  1215. ytPlayerHeight = 502;
  1216. ytPlayerWideWidth = 1280;
  1217. ytPlayerWideHeight = 742;
  1218. }
  1219. else {
  1220. ytPlayerWidth = 640;
  1221. ytPlayerHeight = 382;
  1222. ytPlayerWideWidth = 1066;
  1223. ytPlayerWideHeight = 622;
  1224. }
  1225. if (ytSidebarMarginNormal == 0) ytSidebarMarginWide = ytPlayerWideHeight + 18;
  1226. else ytSidebarMarginWide = ytPlayerHeight + ytSidebarMarginNormal - 12 ;
  1227. }
  1228.  
  1229. page = {win: window, doc: document, body: document.body, url: window.location.href}
  1230. /* Get Player Window */
  1231. var ytPlayerBgColor = '#FFFFFF';
  1232. var ytPlayerWindow = getMyElement ('', 'div', 'id', 'player', -1, false);
  1233. if (!ytPlayerWindow) {
  1234. ytPlayerWindow = getMyElement ('', 'div', 'id', 'p', -1, false);
  1235. ytPlayerBgColor = 'inherit';
  1236. feature['widesize'] = false; }
  1237. if (!ytPlayerWindow) {
  1238. showMyMessage ('!player');
  1239. }
  1240. else {
  1241. blockObject = ytPlayerWindow;
  1242. blockInterval = 30;
  1243.  
  1244. var ytVideoID = null;
  1245. var ytVideosContent = null;
  1246. var ytVideosEncodedFmts = null;
  1247. var ytVideosAdaptiveFmts = null;
  1248. var ytVideosDashmpd, ytHLSVideos;
  1249. /* Clean Player Window */
  1250. var ytWatchPlayer = getMyElement ('', 'div', 'id', 'player-api', -1, false);
  1251. if (ytWatchPlayer) styleMyElement (ytWatchPlayer, {display: 'none'});
  1252. // Stop playlist Autoplay
  1253. var ytNavControl = getMyElement ('', 'div', 'class', 'playlist-nav-controls', 0, false);
  1254. if (ytNavControl) {
  1255. injectScript ('var NextVidEnabled = true;ytspf.enabled = false;ytspf.config["navigate-limit"] = 0;_spf_state.config["navigate-limit"] = 0;var NextVidStopperGetNextValues = function () {var nextLink = document.getElementsByClassName("playlist-behavior-controls")[0].getElementsByTagName("a")[1].href;var nextLinkStart = nextLink.search("v=");var nextLinkEnd = nextLink.search("&");return nextLink.substring(nextLinkStart + 2, nextLinkEnd);};for (var key in _yt_www) {var stringFunction = "" + _yt_www[key];if (stringFunction.search("window.spf.navigate") != -1) {_yt_www[key] = function (a, b) {if (a.search(NextVidStopperGetNextValues()) == -1 || NextVidEnabled == false) {window.location = a;}};}}');
  1256. }
  1257.  
  1258. /* Get Video ID and Thumbnail */
  1259. ytVideoID = page.url.match (/(\?|&)v=(.*?)(&|$)/);
  1260. ytVideoID = (ytVideoID) ? ytVideoID[2] : null;
  1261.  
  1262. var ytVideoThumb = getMyContent (page.url, 'link\\s+itemprop="thumbnailUrl"\\s+href="(.*?)"', false);
  1263. if (!ytVideoThumb) ytVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
  1264. if (!ytVideoThumb) {
  1265. if (ytVideoID) ytVideoThumb = page.win.location.protocol + '//img.youtube.com/vi/' + ytVideoID + '/0.jpg';
  1266. }
  1267. getMyContentGM(page.url.replace(/watch.*?v=/, 'embed/').replace(/&.*$/, ''), '"sts"\\s*:\\s*(\\d+)', false, function(ytVideoSts) {
  1268. 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;
  1269. getMyContentGM(ytVideosInfoURL, 'TEXT', false, function(ytVideosInfo) {
  1270.  
  1271. /* Get Video Title */
  1272. var ytVideoTitle = getMyContent (page.url, 'meta\\s+itemprop="name"\\s+content="(.*?)"', false);
  1273. if (!ytVideoTitle) ytVideoTitle = getMyContent (page.url, 'meta\\s+property="og:title"\\s+content="(.*?)"', false);
  1274. if (!ytVideoTitle) ytVideoTitle = page.doc.title;
  1275. if (ytVideoTitle) {
  1276. ytVideoTitle = ytVideoTitle.replace(/&quot;/g, '\'').replace(/&#34;/g, '\'').replace(/"/g, '\'');
  1277. ytVideoTitle = ytVideoTitle.replace(/&#39;/g, '\'').replace(/'|’/g, '\'');
  1278. ytVideoTitle = ytVideoTitle.replace(/&amp;/g, '&');
  1279. ytVideoTitle = ytVideoTitle.replace(/^\s+|\s+$/, '').replace(/\.+$/g, '');
  1280. ytVideoTitle = ytVideoTitle.replace(/^YouTube\s-\s/, '').replace(/\s-\sYouTube$/, '');
  1281. }
  1282. var ytVideoDuration = getMyContent (page.url, 'meta\\s+itemprop="duration"\\s+content="(.*?)"', false);
  1283. if (ytVideoDuration) {
  1284. ytVideoDuration = parseInt(ytVideoDuration.match(/\d{1,3}M/) ? ytVideoDuration.match(/(\d{1,3})M/)[1] :0) * 60 + parseInt(ytVideoDuration.match(/\d{1,2}S/) ? ytVideoDuration.match(/(\d{1,2})S/)[1] :0);
  1285. }
  1286. var ytVideoUnavailable = getMyElement ('', 'div', 'id', 'player-unavailable', -1, false);
  1287. if (ytVideoUnavailable && ytVideoUnavailable.className.indexOf('hid') == -1) styleMyElement (ytVideoUnavailable, {display: 'inline'});
  1288. myPlayerWindow = getMyElement ('', 'div', 'id', 'MyytWindow', -1, false);
  1289. if (myPlayerWindow) removeMyElement(myPlayerWindow.parentNode,myPlayerWindow);
  1290.  
  1291. /* Get Videos Content */
  1292. var ytScriptURL;
  1293. if (!ytVideoUnavailable || (ytVideoUnavailable.className.indexOf('hid') != -1 || getMyElement ('', 'div', 'id', 'watch7-player-age-gate-content', -1, false))) {
  1294. if (isMutation) {
  1295. var injectedElement = document.getElementById('download-youtube-video-debug-info9');
  1296. if (injectedElement==null) {
  1297. injectedElement = createHiddenElem('pre', 'download-youtube-video-debug-info9');
  1298. }
  1299. injectScript ('if (typeof ytplayer.config == "object" && ytplayer.config != null) document.getElementById("download-youtube-video-debug-info9").appendChild(document.createTextNode(\'"video_id":"\'+ytplayer.config.args.video_id+\'", "js":"\'+ytplayer.config.assets.js+\'", "adaptive_fmts":"\'+ytplayer.config.args.adaptive_fmts+\'", "dashmpd":"\'+ytplayer.config.args.dashmpd+\'", "url_encoded_fmt_stream_map":"\'+ytplayer.config.args.url_encoded_fmt_stream_map+\'"\'));');
  1300. var code = getMyElement('','pre','id','download-youtube-video-debug-info9',-1,false).innerHTML;
  1301. if (code) {
  1302. if (ytVideoID == code.match(/\"video_id\":\s*\"([^\"]+)\"/)[1]) {
  1303. ytVideosEncodedFmts=code.match(/\"url_encoded_fmt_stream_map\":\s*\"([^\"]+)\"/)[1].replace(/&amp;/g,'\\u0026');
  1304. if (ytVideosEncodedFmts == 'undefined') ytVideosEncodedFmts = null;
  1305. if (ytVideosEncodedFmts) ytVideosEncodedFmts = cleanMyContent(ytVideosEncodedFmts, false);
  1306. ytVideosAdaptiveFmts=code.match(/\"adaptive_fmts\":\s*\"([^\"]+)\"/)[1].replace(/&amp;/g,'\\u0026');
  1307. if (ytVideosAdaptiveFmts == 'undefined') ytVideosAdaptiveFmts = null;
  1308. if (ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = cleanMyContent(ytVideosAdaptiveFmts, false);
  1309. ytVideosDashmpd=code.match(/\"dashmpd\":\s*\"([^\"]+)\"/)[1].replace(/&amp;/g,'\\u0026');
  1310. ytScriptURL=code.match(/\"js\":\s*\"([^\"]+)\"/)[1];
  1311. if (!ytScriptURL) ytScriptURL = getMyContent(page.url.replace(/watch.*?v=/, 'embed/').replace(/&.*$/, ''), '"js":\\s*"(.*?)"', true);
  1312. }
  1313. removeMyElement(injectedElement.parentNode, injectedElement);
  1314. }
  1315. }
  1316. else if (!ytVideosEncodedFmts && !ytVideosAdaptiveFmts) {
  1317. ytVideosEncodedFmts = getMyContent(page.url, '"url_encoded_fmt_stream_map":\\s*"(.*?)"', false);
  1318. if (ytVideosEncodedFmts) ytVideosEncodedFmts = cleanMyContent(ytVideosEncodedFmts, false);
  1319. ytVideosAdaptiveFmts = getMyContent(page.url, '"adaptive_fmts":\\s*"(.*?)"', false);
  1320. if (ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = cleanMyContent(ytVideosAdaptiveFmts, false);
  1321. if (!ytVideosEncodedFmts && !ytVideosAdaptiveFmts) {
  1322. if (ytVideosInfo) {
  1323. ytVideosEncodedFmts = ytVideosInfo.match(/url_encoded_fmt_stream_map=(.*?)&/);
  1324. ytVideosEncodedFmts = (ytVideosEncodedFmts) ? ytVideosEncodedFmts[1] : null;
  1325. if (ytVideosEncodedFmts) {
  1326. ytVideosEncodedFmts = cleanMyContent(ytVideosEncodedFmts, true);
  1327. ytVideosContent = ytVideosEncodedFmts;
  1328. }
  1329. if (!ytVideosAdaptiveFmts) {
  1330. ytVideosAdaptiveFmts = ytVideosInfo.match(/adaptive_fmts=(.*?)&/);
  1331. ytVideosAdaptiveFmts = (ytVideosAdaptiveFmts) ? ytVideosAdaptiveFmts[1] : null;
  1332. if (ytVideosAdaptiveFmts) ytVideosAdaptiveFmts = cleanMyContent(ytVideosAdaptiveFmts, true);
  1333. }
  1334. }
  1335. }
  1336. }
  1337. if ((ytVideosEncodedFmts || ytVideosAdaptiveFmts) && (ytVideoUnavailable)) styleMyElement (ytVideoUnavailable, {display: 'none'});
  1338. }
  1339.  
  1340. if (ytVideosEncodedFmts) {
  1341. ytVideosContent = ytVideosEncodedFmts;
  1342. }
  1343. if (ytVideosAdaptiveFmts) {
  1344. if (ytVideosContent) ytVideosContent += ',' + ytVideosAdaptiveFmts;
  1345. else ytVideosContent = ytVideosAdaptiveFmts;
  1346. }
  1347.  
  1348. /* Get DASH Content */
  1349. ytVideosDashmpd = ytVideosInfo.match(/dashmpd=(.*?)&/);
  1350. ytVideosDashmpd = (ytVideosDashmpd) ? ytVideosDashmpd[1] : null;
  1351. if (ytVideosDashmpd) ytVideosDashmpd = cleanMyContent(ytVideosDashmpd, true);
  1352.  
  1353. /* Get HLS Content */
  1354. if (!ytVideosContent) {
  1355. ytHLSVideos = getMyContent(page.url, '"hlsvp":\\s*"(.*?)"', false);
  1356. if (ytHLSVideos) ytHLSVideos = cleanMyContent(ytHLSVideos, false);
  1357. else if (ytVideosInfo) {
  1358. ytHLSVideos = ytVideosInfo.match(/hlsvp=(.*?)&/);
  1359. ytHLSVideos = (ytHLSVideos) ? ytHLSVideos[1] : null;
  1360. if (ytHLSVideos) ytHLSVideos = cleanMyContent(ytHLSVideos, true);
  1361. }
  1362. }
  1363. function getYoutubeVideos(ytVideosContent, yturl) {
  1364. if (yturl != page.url) return;
  1365.  
  1366. /* Parse HLS */
  1367. function ytHLS(ytHLSVideos) {
  1368. var ytHLSFormats = {
  1369. '92': 'Very Low Definition MP4',
  1370. '93': 'Low Definition MP4',
  1371. '94': 'Standard Definition MP4',
  1372. '95': 'High Definition MP4'
  1373. };
  1374. ytVideoList["HLS Any Definition MP4"] = ytHLSVideos;
  1375. if (ytHLSContent) {
  1376. var ytHLSMatcher = new RegExp('(http.*?m3u8)', 'g');
  1377. ytHLSVideos = ytHLSContent.match(ytHLSMatcher);
  1378. var ytHLSVideo, ytVideoCodeParse, ytVideoCode, myVideoCode;
  1379. if (ytHLSVideos) {
  1380. for (var i = 0; i < ytHLSVideos.length; i++) {
  1381. ytHLSVideo = ytHLSVideos[i];
  1382. ytVideoCodeParse = ytHLSVideo.match(/\/itag\/(\d{1,3})\//);
  1383. ytVideoCode = (ytVideoCodeParse) ? ytVideoCodeParse[1] : null;
  1384. if (ytVideoCode) {
  1385. myVideoCode = ytHLSFormats[ytVideoCode];
  1386. if (myVideoCode && ytHLSVideo) {
  1387. ytVideoList[myVideoCode] = ytHLSVideo;
  1388. }
  1389. }
  1390. }
  1391. }
  1392. }
  1393. ytVideoTitle = null;
  1394. ytPlayer (yturl);
  1395. }
  1396.  
  1397. function ytPlayer (yturl) {
  1398. if (yturl != page.url) return;
  1399. window.removeEventListener('resize', ytPlayerResize, false);
  1400.  
  1401. /* Create Player */
  1402. var ytDefaultVideo = 'Low Definition MP4';
  1403. var player = {
  1404. 'playerSocket': ytPlayerWindow,
  1405. 'playerWindow': myPlayerWindow,
  1406. 'videoList': ytVideoList,
  1407. 'videoPlay': ytDefaultVideo,
  1408. 'videoThumb': ytVideoThumb,
  1409. 'videoDuration': ytVideoDuration,
  1410. 'playerWidth': ytPlayerWidth,
  1411. 'playerHeight': ytPlayerHeight,
  1412. 'playerWideWidth': ytPlayerWideWidth,
  1413. 'playerWideHeight': ytPlayerWideHeight,
  1414. 'sidebarWindow': ytSidebarWindow,
  1415. 'sidebarMarginNormal': ytSidebarMarginNormal,
  1416. 'sidebarMarginWide': ytSidebarMarginWide
  1417. };
  1418.  
  1419. ytPlayerResize = function () {
  1420. ytSizes();
  1421. var ytWatchAppBar = getMyElement ('', 'div', 'id', 'watch-appbar-playlist', -1, false);
  1422. if (!ytWatchAppBar) ytWatchAppBar = getMyElement ('', 'div', 'id', 'playlist', -1, false);
  1423. if (ytWatchAppBar) styleMyElement (ytWatchAppBar, {height: + ytPlayerHeight + 'px'});
  1424. player['playerWidth'] = ytPlayerWidth;
  1425. player['playerHeight'] = ytPlayerHeight;
  1426. player['playerWideWidth'] = ytPlayerWideWidth;
  1427. player['playerWideHeight'] = ytPlayerWideHeight;
  1428. player['sidebarMarginWide'] = ytSidebarMarginWide;
  1429. resizeMyPlayer(player, 'widesize');
  1430. }
  1431.  
  1432. option['definitions'] = ['Ultra High Definition', 'Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
  1433. option['containers'] = ['MP4', 'WebM', 'FLV', '3GP', 'Any'];
  1434. HeadWindow = getMyElement('', 'div', 'id', 'masthead-positioner', -1, false);
  1435. createMyPlayer (player);
  1436.  
  1437. /* Update Sizes */
  1438. window.addEventListener('resize', ytPlayerResize,false);
  1439. }
  1440.  
  1441. /* Get Sizes */
  1442. ytSizes();
  1443.  
  1444. /* Hide Player Window */
  1445. var ytPlaceholderPlayer = getMyElement ('', 'div', 'id', 'placeholder-player', -1, false);
  1446. if (ytPlaceholderPlayer) styleMyElement (ytPlaceholderPlayer, {display: 'none'});
  1447. var ytPlayerContainer = getMyElement ('', 'div', 'id', 'player-container', -1, false);
  1448. if (ytPlayerContainer) styleMyElement (ytPlayerContainer, {display: 'none'});
  1449.  
  1450. /* Hide Sidebar Ads */
  1451. var ytSidebarAds = getMyElement ('', 'div', 'id', 'watch7-sidebar-ads', -1, false);
  1452. if (ytSidebarAds) styleMyElement (ytSidebarAds, {display: 'none'});
  1453.  
  1454. /* Playlist */
  1455. var ytWatchAppBar = getMyElement ('', 'div', 'id', 'watch-appbar-playlist', -1, false);
  1456. if (!ytWatchAppBar) ytWatchAppBar = getMyElement ('', 'div', 'id', 'playlist', -1, false);
  1457. if (ytWatchAppBar) styleMyElement (ytWatchAppBar, {height: + ytPlayerHeight + 'px'});
  1458.  
  1459. /* My Player Window */
  1460. myPlayerWindow = createMyElement ('div', '', '', '', '');
  1461. myPlayerWindow.id = 'MyytWindow';
  1462. styleMyElement (ytPlayerWindow, {top: '0px'});
  1463. styleMyElement (myPlayerWindow, {position: 'relative', width: ytPlayerWidth + 'px', height: ytPlayerHeight +'px', backgroundColor: ytPlayerBgColor, zIndex: '99999'});
  1464. appendMyElement (ytPlayerWindow, myPlayerWindow);
  1465.  
  1466. /* Get Videos */
  1467. var ytVideoUnavailable = getMyElement ('', 'div', 'id', 'player-unavailable', -1, false);
  1468. var ytVideoList = {};
  1469. if (ytVideosContent) {
  1470. var ytVideoFound = false;
  1471. var veVideoFound = false;
  1472. var ytVideoFormats = {
  1473. '5': 'Very Low Definition FLV',
  1474. '17': 'Very Low Definition 3GP',
  1475. '18': 'Low Definition MP4',
  1476. '22': 'High Definition MP4',
  1477. '34': 'Low Definition FLV',
  1478. '35': 'Standard Definition FLV',
  1479. '36': 'Low Definition 3GP',
  1480. '37': 'Full High Definition MP4',
  1481. '38': 'Ultra High Definition MP4',
  1482. '43': 'Low Definition WebM',
  1483. '44': 'Standard Definition WebM',
  1484. '45': 'High Definition WebM',
  1485. '46': 'Full High Definition WebM',
  1486. '82': 'Low Definition 3D MP4',
  1487. '83': 'Standard Definition 3D MP4',
  1488. '84': 'High Definition 3D MP4',
  1489. '85': 'Full High Definition 3D MP4',
  1490. '100': 'Low Definition 3D WebM',
  1491. '101': 'Standard Definition 3D WebM',
  1492. '102': 'High Definition 3D WebM',
  1493. '135': 'Standard Definition Video MP4',
  1494. '136': 'High Definition Video MP4',
  1495. '137': 'Full High Definition Video MP4',
  1496. '138': 'Ultra High Definition Video MP4',
  1497. '139': 'Low Bitrate Audio MP4',
  1498. '140': 'Medium Bitrate Audio MP4',
  1499. '141': 'High Bitrate Audio MP4',
  1500. '171': 'Medium Bitrate Audio WebM',
  1501. '172': 'High Bitrate Audio WebM',
  1502. '244': 'Standard Definition Video WebM',
  1503. '247': 'High Definition Video WebM',
  1504. '248': 'Full High Definition Video WebM',
  1505. '249': 'Low Bitrate Audio Opus',
  1506. '250': 'Medium Bitrate Audio Opus',
  1507. '251': 'High Bitrate Audio Opus',
  1508. '266': 'Ultra High Definition Video MP4',
  1509. '272': 'Ultra High Definition Video WebM',
  1510. '298': 'High Definition Video MP4',
  1511. '299': 'Full High Definition Video MP4',
  1512. '302': 'High Definition Video WebM',
  1513. '303': 'Full High Definition Video WebM',
  1514. '313': 'Ultra High Definition Video WebM'
  1515. };
  1516. var ytVideos = ytVideosContent.split(',');
  1517. var ytVideoParse, ytVideoCodeParse, ytVideoCode, myVideoCode, ytVideo;
  1518. for (var i = 0; i < ytVideos.length; i++) {
  1519. if (!ytVideos[i].match(/^url/)) {
  1520. ytVideoParse = ytVideos[i].match(/(.*)(url=.*$)/);
  1521. if (ytVideoParse) ytVideos[i] = ytVideoParse[2] + '&' + ytVideoParse[1];
  1522. }
  1523. ytVideoCodeParse = ytVideos[i].match (/itag=(\d{1,3})/);
  1524. ytVideoCode = (ytVideoCodeParse) ? ytVideoCodeParse[1] : null;
  1525. if (ytVideoCode) {
  1526. myVideoCode = ytVideoFormats[ytVideoCode];
  1527. if (myVideoCode) {
  1528. ytVideo = cleanMyContent(ytVideos[i], true);
  1529. ytVideo = ytVideo.replace (/url=/, '').replace(/&$/, '');
  1530. if (ytVideo.match(/itag=/) && ytVideo.match(/itag=/g).length > 1) {
  1531. if (ytVideo.match(/itag=\d{1,3}&/)) ytVideo = ytVideo.replace(/itag=\d{1,3}&/, '');
  1532. else if (ytVideo.match(/&itag=\d{1,3}/)) ytVideo = ytVideo.replace(/&itag=\d{1,3}/, '');
  1533. }
  1534. if (ytVideo.match(/clen=/) && ytVideo.match(/clen=/g).length > 1) {
  1535. if (ytVideo.match(/clen=\d+&/)) ytVideo = ytVideo.replace(/clen=\d+&/, '');
  1536. else if (ytVideo.match(/&clen=\d+/)) ytVideo = ytVideo.replace(/&clen=\d+/, '');
  1537. }
  1538. if (ytVideo.match(/lmt=/) && ytVideo.match(/lmt=/g).length > 1) {
  1539. if (ytVideo.match(/lmt=\d+&/)) ytVideo = ytVideo.replace(/lmt=\d+&/, '');
  1540. else if (ytVideo.match(/&lmt=\d+/)) ytVideo = ytVideo.replace(/&lmt=\d+/, '');
  1541. }
  1542. if (ytVideo.match(/type=(video|audio).*?&/)) ytVideo = ytVideo.replace(/type=(video|audio).*?&/, '');
  1543. else ytVideo = ytVideo.replace(/&type=(video|audio).*$/, '');
  1544. if (ytVideo.match(/&xtags=/)) ytVideo = ytVideo.replace(/&xtags=/, '');
  1545. if (ytVideo.match(/&sig=/)) ytVideo = ytVideo.replace (/&sig=/, '&signature=');
  1546. else if (ytVideo.match(/&s=/)) {
  1547. var ytSig = ytVideo.match(/&s=(.*?)(&|$)/);
  1548. if (ytSig) {
  1549. var s = decryptSignature(ytSig[1]);
  1550. ytVideo = ytVideo.replace(/&s=.*?(&|$)/, '&signature=' + s + '$1');
  1551. }
  1552. else ytVideo = '';
  1553. }
  1554. ytVideo = cleanMyContent (ytVideo, true);
  1555. if (ytVideo.indexOf('ratebypass') == -1) ytVideo += '&ratebypass=yes';
  1556. if (ytVideo && ytVideo.indexOf('http') == 0) {
  1557. if (!ytVideoFound) ytVideoFound = true;
  1558. ytVideoList[myVideoCode] = ytVideo;
  1559. }
  1560. }
  1561. }
  1562. }
  1563. if (ytVideosDashmpd) {
  1564. if (ytVideosDashmpd.match(/\/signature\//)) ytVideoList['DASH MP4'] = ytVideosDashmpd;
  1565. else if (ytVideosDashmpd.match(/\/s\//)) {
  1566. var ytSig = ytVideosDashmpd.match(/\/s\/(.*?)\//);
  1567. if (ytSig) {
  1568. var s = decryptSignature(ytSig[1]);
  1569. ytVideoList['DASH MP4'] = ytVideosDashmpd.replace(/\/s\/.*?(\/.*$)/, '\/signature\/' + s + '$1');
  1570. }
  1571. }
  1572. }
  1573. if (ytHLSVideos) {
  1574. ytVideoList["HLS Any Definition MP4"] = ytHLSVideos;
  1575. if (!ytVideoFound) ytVideoFound = true;
  1576. }
  1577. if (ytVideoFound) {
  1578. ytPlayer(yturl);
  1579. }
  1580. else {
  1581. if (ytVideosContent.indexOf('conn=rtmp') != -1) showMyMessage ('!support');
  1582. else showMyMessage ('!videos');
  1583. } /* End Create Player */
  1584. }
  1585. else {
  1586. if (ytVideosDashmpd) {
  1587. if (ytVideosDashmpd.match(/\/signature\//)) ytVideoList['DASH MP4'] = ytVideosDashmpd;
  1588. else if (ytVideosDashmpd.match(/\/s\//)) {
  1589. var ytSig = ytVideosDashmpd.match(/\/s\/(.*?)\//);
  1590. if (ytSig) {
  1591. var s = decryptSignature(ytSig[1]);
  1592. ytVideoList['DASH MP4'] = ytVideosDashmpd.replace(/\/s\/.*?(\/.*$)/, '\/signature\/' + s + '$1');
  1593. }
  1594. }
  1595. }
  1596. if (ytHLSVideos) {
  1597. var ytHLSContent = getMyContent(ytHLSVideos, 'TEXT', false);
  1598. ytHLS(ytHLSVideos);
  1599. }
  1600. else {
  1601. if (ytVideoUnavailable && ytVideoUnavailable.className.indexOf('hid') == -1) removeMyElement(ytPlayerWindow, myPlayerWindow)
  1602. else showMyMessage ('!content');
  1603. }
  1604. }
  1605. }
  1606. /* Get Script URL */
  1607. if (!ytScriptURL) ytScriptURL = getMyContent(page.url, '"js":\\s*"(.*?)"', true);
  1608. if (!ytScriptURL) ytScriptURL = getMyContent(page.url.replace(/watch.*?v=/, 'embed/').replace(/&.*$/, ''), '"js":\\s*"(.*?)"', true);
  1609. ytScriptURL = page.win.location.protocol + '//' + page.win.location.hostname + ytScriptURL;
  1610. var DECODEARRDAT = 'decodeArrayData';
  1611. decodeArray = getMyOption(DECODEARRDAT);
  1612. if (decodeArray) decodeArray = decodeArray.split(',');
  1613. if (ytScriptURL && ytVideosContent && ytVideosContent.match(/&s=/) && (!decodeArray || decodeArray.length==0)) {
  1614. try {
  1615. crossXmlHttpRequest({
  1616. method:'GET',
  1617. url:ytScriptURL,
  1618. onload:function(response) {
  1619. if (response.readyState === 4 && response.status === 200 && response.responseText) {
  1620. decodeArray = findSignatureCode(response.responseText);
  1621. setMyOptions(DECODEARRDAT, decodeArray.toString());
  1622. getYoutubeVideos(ytVideosContent, page.url);
  1623. }
  1624. else {
  1625. showMyMessage('other', 'Couldn\'t get the signature content. Please report it <a href="' + contact + '" style="color:#00892C">here</a>.');
  1626. }
  1627. },
  1628. onerror: function() {
  1629. showMyMessage('other', 'Couldn\'t make the request. Make sure your browser user scripts extension supports cross-domain requests.');
  1630. }
  1631. });
  1632. } catch(e) { }
  1633. } else {
  1634. getYoutubeVideos(ytVideosContent, page.url);
  1635. try {
  1636. crossXmlHttpRequest({
  1637. method:'GET',
  1638. url:ytScriptURL,
  1639. onload:function(response) {
  1640. if (response.readyState === 4 && response.status === 200 && response.responseText) {
  1641. var retArray = findSignatureCode(response.responseText);
  1642. if (retArray && (retArray.toString() != decodeArray.toString()) && ytVideosContent.match(/&s=/)) {
  1643. decodeArray = retArray;
  1644. setMyOptions(DECODEARRDAT, decodeArray.toString());
  1645. myPlayerWindow = getMyElement ('', 'div', 'id', 'MyytWindow', -1, false);
  1646. if (myPlayerWindow) removeMyElement(myPlayerWindow.parentNode,myPlayerWindow);
  1647. getYoutubeVideos(ytVideosContent, page.url);
  1648. }
  1649. }
  1650. }
  1651. });
  1652. } catch(e) { }
  1653. }
  1654. });
  1655. });
  1656. }
  1657. }
  1658.  
  1659. function onNodeInserted(e) {
  1660. if (page.url != window.location.href) {
  1661. myPlayerWindow = getMyElement ('', 'div', 'id', 'MyytWindow', -1, false);
  1662. if (myPlayerWindow) removeMyElement(myPlayerWindow.parentNode,myPlayerWindow);
  1663. }
  1664. if (e && e.target && e.target.id=='watch7-main-container') {
  1665. setTimeout(function() { yt_run("NodeInserted"); }, 0);
  1666. }
  1667. }
  1668. if (page.url.indexOf('youtube.com/watch\?v=') != -1) yt_run();
  1669. var content=document.getElementById('content');
  1670. if (content) {
  1671. var mo=window.MutationObserver||window.MozMutationObserver||window.WebKitMutationObserver;
  1672. if(typeof mo!=='undefined') {
  1673. var observer=new mo(function(mutations) {
  1674. mutations.forEach(function(mutation) {
  1675. if(mutation.addedNodes!==null) {
  1676. for (var i=0; i<mutation.addedNodes.length; i++) {
  1677. if (mutation.addedNodes[i].id=='watch7-main-container') {
  1678. // if (mutation.addedNodes[i].id=='page') {
  1679. yt_run("Mutation");
  1680. break;
  1681. }
  1682. }
  1683. }
  1684. });
  1685. if (page.url != window.location.href) {
  1686. myPlayerWindow = getMyElement ('', 'div', 'id', 'MyytWindow', -1, false);
  1687. if (myPlayerWindow) removeMyElement(myPlayerWindow.parentNode,myPlayerWindow);
  1688. }
  1689. });
  1690. observer.observe(content, {childList: true, subtree: true});
  1691. } else { // MutationObserver fallback for old browsers
  1692. if (document.implementation.hasFeature('MutationEvents','2.0')) {
  1693. pagecontainer.addEventListener('DOMNodeInserted', onNodeInserted, false);
  1694. } else {
  1695. page.win.setInterval(function() {
  1696. nurl = window.location.href;
  1697. if (page.url != nurl) window.location.href = nurl;
  1698. }, 500)
  1699. }
  1700. }
  1701. }
  1702. }
  1703.  
  1704. // =====DailyMotion===== //
  1705. else if (page.url.indexOf('dailymotion.com/video') != -1) {
  1706.  
  1707. /* Get Player Window */
  1708. var dmPlayerWindow = getMyElement ('', 'div', 'class', 'player-container', 0, false);
  1709. if (!dmPlayerWindow) {
  1710. showMyMessage ('!player');
  1711. }
  1712. else {
  1713. /* Get Video Thumbnail */
  1714. var dmVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
  1715. var dmVideoDuration = getMyContent (page.url, 'meta\\s+property="video:duration"\\s+content="(.*?)"', false);
  1716. if (dmVideoDuration) dmVideoDuration = parseInt(dmVideoDuration);
  1717.  
  1718. /* Get Videos Content */
  1719. var dmVideosContent = getMyContent(page.url, '"qualities":\\{(.*?)\\]\\},', false);
  1720. if (!dmVideosContent) dmVideosContent = getMyContent(page.url.replace(/\/video\//, "/embed/video/"), '"qualities":\\{(.*?)\\]\\},', false);
  1721.  
  1722. /* Player Size */
  1723. var dmSidebarWidth = 320;
  1724. var dmSidebarWindow = getMyElement ('', 'div', 'class', 'sidebar', 0, false);
  1725. var dmSidebarWindowStyle = (dmSidebarWindow) ? dmSidebarWindow.currentStyle || window.getComputedStyle(dmSidebarWindow) : null;
  1726. var dmPlayerWidth, dmPlayerHeight;
  1727. var dmPlayerWideWidth, dmPlayerWideHeight;
  1728. var dmSidebarMarginWide;
  1729. function dmGetSizes() {
  1730. dmPlayerWidth = dmPlayerWindow.clientWidth;
  1731. dmPlayerHeight = Math.ceil(dmPlayerWidth / (16 / 9)) + 22;
  1732. if (dmSidebarWindow && dmSidebarWindowStyle) dmSidebarWidth = parseInt(dmSidebarWindowStyle.width);
  1733. dmPlayerWideWidth = dmPlayerWidth + dmSidebarWidth;
  1734. dmPlayerWideHeight = Math.ceil(dmPlayerWideWidth / (16 / 9)) + 22;
  1735. dmSidebarMarginWide = dmPlayerWideHeight + 30
  1736. }
  1737. function dmUpdateSizes() {
  1738. setTimeout(function() {
  1739. dmGetSizes();
  1740. player['playerWidth'] = dmPlayerWidth;
  1741. player['playerHeight'] = dmPlayerHeight;
  1742. player['playerWideWidth'] = dmPlayerWideWidth;
  1743. player['playerWideHeight'] = dmPlayerWideHeight;
  1744. player['sidebarMarginWide'] = dmSidebarMarginWide;
  1745. resizeMyPlayer(player, 'widesize');
  1746. styleMyElement (dmPlayerWindow, {overflow: 'visible', height: '100%'});
  1747. },350);
  1748. }
  1749. dmGetSizes();
  1750.  
  1751. /* My Player Window */
  1752. var myPlayerWindow = createMyElement ('div', '', '', '', '');
  1753. styleMyElement (myPlayerWindow, {position: 'relative',width: dmPlayerWidth + 'px', height: dmPlayerHeight + 'px', backgroundColor: '#F4F4F4', zIndex: '99999'});
  1754. modifyMyElement (dmPlayerWindow, 'div', '', false, true);
  1755. appendMyElement (dmPlayerWindow, myPlayerWindow);
  1756. blockObject = dmPlayerWindow;
  1757.  
  1758. /* Fix Visibility & Height */
  1759. var dmPlayerJSBox = getMyElement ('', 'div', 'class', 'js-player-box', 0, false);
  1760. if (dmPlayerJSBox) styleMyElement(dmPlayerJSBox, {overflow: 'visible', height: '100%', backgroundColor: '#F4F4F4'});
  1761. else styleMyElement(dmPlayerWindow.parentNode, {overflow: 'visible', height: '100%', backgroundColor: '#F4F4F4'});
  1762. page.win.setTimeout(function() {styleMyElement (dmPlayerWindow, {overflow: 'visible', height: '100%'});}, 2000);
  1763.  
  1764. /* Fix Right Ad Issue */
  1765. var dmMcRight = getMyElement ('', 'div', 'id', 'mc_Right', -1, false);
  1766. if (dmMcRight) {
  1767. var dmWaitForAdTime = 20;
  1768. var dmPlayerWidthPrev = dmPlayerWidth;
  1769. var dmWaitForAdFunc = page.win.setInterval(function() {
  1770. if(dmMcRight.clientWidth) {
  1771. dmUpdateSizes();
  1772. if (dmPlayerWidth != dmPlayerWidthPrev) clearInterval(dmWaitForAdFunc);
  1773. }
  1774. dmWaitForAdTime--;
  1775. if (dmWaitForAdTime == 0) clearInterval(dmWaitForAdFunc);
  1776. }, 250);
  1777. }
  1778.  
  1779. /* Resize Event */
  1780. page.win.addEventListener('resize', dmUpdateSizes, false);
  1781.  
  1782. /* Hide Top Ads */
  1783. var dmMcTop = getMyElement ('', 'div', 'id', 'mc_Top', -1, false);
  1784. if (dmMcTop) styleMyElement(dmMcTop, {display: 'none'});
  1785.  
  1786. /* Get Videos */
  1787. if (dmVideosContent) {
  1788. 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'};
  1789. var dmVideoList = {};
  1790. var dmVideoFound = false;
  1791. var dmVideoParser, dmVideoParse, myVideoCode, dmVideo;
  1792. for (var dmVideoCode in dmVideoFormats) {
  1793. dmVideoParser = '"' + dmVideoCode + '".*?"url":"(.*?)"';
  1794. dmVideoParse = dmVideosContent.match (dmVideoParser);
  1795. if (!dmVideoParse) {
  1796. dmVideoParser = '"' + dmVideoCode + '".*?"type":"application.*?mpegURL","url":"(.*?)"';
  1797. dmVideoParse = dmVideosContent.match(dmVideoParser);
  1798. }
  1799. dmVideo = (dmVideoParse) ? dmVideoParse[1] : null;
  1800. if (dmVideo) {
  1801. if (!dmVideoFound) dmVideoFound = true;
  1802. dmVideo = cleanMyContent(dmVideo, true);
  1803. myVideoCode = dmVideoFormats[dmVideoCode];
  1804. if (!dmVideoList[myVideoCode]) dmVideoList[myVideoCode] = dmVideo;
  1805. }
  1806. }
  1807.  
  1808. if (dmVideoFound) {
  1809.  
  1810. /* Create Player */
  1811. var dmDefaultVideo = 'Low Definition MP4';
  1812. var player = {
  1813. 'playerSocket': dmPlayerWindow,
  1814. 'playerWindow': myPlayerWindow,
  1815. 'videoList': dmVideoList,
  1816. 'videoPlay': dmDefaultVideo,
  1817. 'videoThumb': dmVideoThumb,
  1818. 'videoDuration': dmVideoDuration,
  1819. 'playerWidth': dmPlayerWidth,
  1820. 'playerHeight': dmPlayerHeight,
  1821. 'playerWideWidth': dmPlayerWideWidth,
  1822. 'playerWideHeight': dmPlayerWideHeight,
  1823. 'sidebarWindow': dmSidebarWindow,
  1824. 'sidebarMarginNormal': 0,
  1825. 'sidebarMarginWide': dmSidebarMarginWide
  1826. };
  1827. feature['container'] = false;
  1828. option['definitions'] = ['Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
  1829. option['containers'] = ['MP4'];
  1830. createMyPlayer (player);
  1831.  
  1832. /* Fix HTML5 video duplicate on click - by seezuoto */
  1833. page.body.addEventListener('click', function(e) {
  1834. if (e.target.id === 'vtVideo' || (e.target.tagName === 'DIV' && !e.target.innerHTML.match(/^\s*more\s*$/))) {
  1835. e.stopPropagation();
  1836. }
  1837. });
  1838.  
  1839. /* Fix panel */
  1840. styleMyElement(player['playerContent'], {marginTop: '7px'});
  1841.  
  1842. /* Fix Info Position On Widesize */
  1843. player['buttonWidesize'].addEventListener('click', function() {
  1844. styleMyElement (dmPlayerWindow.parentNode, {minHeight: player['contentHeight'] + 50 + 'px'});
  1845. }, false);
  1846. } else {
  1847. showMyMessage ('!videos');
  1848. }
  1849. } else {
  1850. showMyMessage ('!content');
  1851. }
  1852. }
  1853. }
  1854.  
  1855. // =====Vimeo===== //
  1856. else if (page.url.match(/https?:\/\/(www\.)?vimeo.com\//)) {
  1857.  
  1858. function vimeo_run(viPlayerId) {
  1859. if (viPlayerId && page.url == window.location.href) return;
  1860. page = {win: window, doc: document, body: document.body, url: window.location.href};
  1861.  
  1862. var PlayerHeight, PlayerWidth, viVideo, myVideoCode;
  1863. var viVideoID = null;
  1864. var viVideoSignature = null;
  1865. var viVideoTimestamp = null;
  1866. var viPlayerWindow = null;
  1867. var viVideoRegex;
  1868. var viVideoFormats = {'HLS': 'HTTP Live Streaming','1080p': 'Full High Definition MP4','720p': 'High Definition MP4', '540p': 'Standard Definition MP4', '480p': 'Standard Definition MP4', '360p': 'Low Definition MP4', '270p': 'Very Low Definition MP4'};
  1869. /* Video Type */
  1870. var viVideoPage = page.url.match(/vimeo.com\/\d+/) ? true : false;
  1871. /* Get Player Window */
  1872. for (i=0; i<getMyElement ('', 'div', 'class', 'player_container', -1, false).length; i++) {
  1873. var viPlayerWindow = getMyElement ('', 'div', 'class', 'player_container', i, false);
  1874. styleMyElement (viPlayerWindow.parentNode, {height: '100%', transformStyle: 'flat', transform: 'none'});
  1875. // if (page.body.innerHTML.match(/open\("GET","(https?\:\/\/player.*?)"/)) PlayerHeight = viPlayerWindow.clientHeight;
  1876. // else PlayerHeight = viPlayerWindow.clientHeight;
  1877. // else PlayerHeight = viPlayerWindow.clientHeight + 22;
  1878. PlayerHeight = viPlayerWindow.clientHeight;
  1879. PlayerWidth = viPlayerWindow.clientWidth;
  1880. var viScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
  1881. var viPlayerLeft = Math.floor((viScreenWidth - PlayerWidth) / 2);
  1882. if (!viPlayerWindow) {
  1883. showMyMessage ('!player');
  1884. } else {
  1885. /* Get Videos Content */
  1886. viVideoRegex = 'data-fallback-url=".*?(\\d{6,10})\\/.*?"';
  1887. viVideoID = page.body.innerHTML.match(RegExp(viVideoRegex,'g'))[i];
  1888. if (viVideoID) viVideoID = viVideoID.match(RegExp(viVideoRegex))[1];
  1889. viVideoURL = page.win.location.protocol + "//vimeo.com/" + viVideoID;
  1890. getMyContentGM(viVideoURL,'TEXT',false, function (res1) {
  1891. // var viVideoSource = res1.match(/open\("GET","(https?\:\/\/player.*?)"/);
  1892. // if (viVideoSource) viVideoSource = viVideoSource[1];
  1893. // else viVideoSource = res1.match('{"config_url":"(.*?)"')[1].replace (/\\u0025/g,'%').replace (/\\u0026/g,'&').replace (/\\/g,'');
  1894. // else viVideoSource = res1.match('data-config-url="(.*?)"')[1].replace(/&amp;/g, '&');
  1895. var viVideoSource = res1.match('{"config_url":"(.*?)"')[1].replace (/\\u0025/g,'%').replace (/\\u0026/g,'&').replace (/\\/g,'');
  1896. getMyContentGM(viVideoSource,'TEXT',false, function (res2) {
  1897. /* Get Videos */
  1898. var viVideosContent = JSON.parse(res2);
  1899. var viVideoList = {};
  1900. var myVideoCode;
  1901. var viVideoFound = false;
  1902. if (viVideosContent) {
  1903. var viVideoID = viVideosContent.video.id;
  1904. var viVideoThumb = viVideosContent.video.thumbs['960'];
  1905. if (!viVideoThumb) viVideoThumb = viVideosContent.video.thumbs['1280'];
  1906. if (!viVideoThumb) viVideoThumb = viVideosContent.video.thumbs['640'];
  1907. var viVideoDuration = viVideosContent.video.duration;
  1908. } else {
  1909. showMyMessage ('!content');
  1910. }
  1911.  
  1912. /* My Player Window */
  1913. var viPlayerWindow = getMyElement ('', 'div', 'class', 'player_container', -1, false);
  1914. var viVideoRegex = 'data-fallback-url=".*?(\\d{6,10})\\/.*?"';
  1915. for (i=0;i<viPlayerWindow.length;i++) {
  1916. if (viPlayerWindow[i].innerHTML.match(viVideoRegex) && viPlayerWindow[i].innerHTML.match(viVideoRegex)[1] == viVideoID) {
  1917. viPlayerWindow = viPlayerWindow[i];
  1918. break;
  1919. }
  1920. }
  1921. var viPlayerElement = getMyElement (viPlayerWindow, 'div', 'class', 'player', 0, false);
  1922. cleanMyElement (viPlayerElement, true);
  1923. modifyMyElement (viPlayerElement, 'div', '', true);
  1924. myPlayerWindow = getMyElement (viPlayerWindow, 'div', 'class', 'MyviWindow', 0, false);
  1925. if (myPlayerWindow) removeMyElement(myPlayerWindow.parentNode,myPlayerWindow);
  1926. myPlayerWindow = createMyElement ('div', '', '', '', '');
  1927. myPlayerWindow.className = 'MyviWindow';
  1928. styleMyElement (myPlayerWindow, {position: 'relative', width: PlayerWidth + 'px', height: PlayerHeight + 'px', backgroundColor: '#F4F4F4', zIndex: '99999'});
  1929. modifyMyElement (viPlayerWindow, 'div', '', false, true);
  1930. styleMyElement (viPlayerWindow, {height: '100%', left: viPlayerLeft + 'px', transform: 'none'});
  1931.  
  1932. appendMyElement (viPlayerWindow, myPlayerWindow);
  1933. if (viVideosContent) {
  1934. if (viVideosContent.request.files.hls && viVideosContent.request.files.hls.cdns && viVideosContent.request.files.hls.default_cdn) {
  1935. viVideoList[viVideoFormats['HLS']] = viVideosContent.request.files.hls.cdns[viVideosContent.request.files.hls.default_cdn].url
  1936. }
  1937. for (var viVideoCode in viVideoFormats) {
  1938. for (var i=0; i < viVideosContent.request.files.progressive.length; i++) {
  1939. if (viVideosContent.request.files.progressive[i].quality == viVideoCode) {
  1940. viVideoFound = true;
  1941. myVideoCode = viVideoFormats[viVideoCode];
  1942. viVideoList[myVideoCode] = viVideosContent.request.files.progressive[i].url;
  1943. }
  1944. }
  1945. }
  1946. }
  1947. if (viVideoFound) {
  1948. /* Create Player */
  1949. var viDefaultVideo = 'Low Definition MP4';
  1950. var player = {
  1951. 'playerSocket': viPlayerWindow,
  1952. 'playerWindow': myPlayerWindow,
  1953. 'videoList': viVideoList,
  1954. 'videoPlay': viDefaultVideo,
  1955. 'videoThumb': viVideoThumb,
  1956. 'videoDuration': viVideoDuration,
  1957. 'playerWidth': PlayerWidth,
  1958. 'playerHeight': PlayerHeight
  1959. };
  1960. feature['container'] = false;
  1961. feature['widesize'] = false;
  1962. option['definitions'] = ['Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
  1963. option['containers'] = ['MP4'];
  1964. HeadWindow = getMyElement('', 'div', 'id', 'topnav_desktop', -1, false);
  1965. styleMyElement(HeadWindow, {zIndex: '50'});
  1966. createMyPlayer (player);
  1967.  
  1968. /* Fix panel */
  1969. if (viVideoPage) styleMyElement(player['playerContent'], {marginTop: '5px'});
  1970. else styleMyElement(player['playerContent'], {marginTop: '3px'});
  1971.  
  1972. } else {
  1973. showMyMessage ('!videos');
  1974. }
  1975. });
  1976. });
  1977. }
  1978. }
  1979. }
  1980.  
  1981. function onNodeInserted(e) {
  1982. if (e && e.target && (typeof e.target.className !== 'undefined') && e.target.className.className == 'video-wrapper') {
  1983. setTimeout(function() { vimeo_run(); }, 0);
  1984. }
  1985. }
  1986.  
  1987. var paginationholder = getMyElement ('', 'div', 'class', 'pagination_holder', 0, false);
  1988. vimeo_run();
  1989. var content=document.getElementById('content');
  1990. window.addEventListener("hashchange", onNodeInserted(), false)
  1991. var mo=window.MutationObserver||window.MozMutationObserver||window.WebKitMutationObserver;
  1992. if (content && typeof mo!=='undefined') {
  1993. var observer=new mo(function(mutations) {
  1994. mutations.forEach(function(mutation) {
  1995. if(mutation.addedNodes!==null && mutation.addedNodes.length > 0) {
  1996. for (var i=0; i<mutation.addedNodes.length; i++) {
  1997. if (typeof mutation.addedNodes[i].className !== 'undefined') if (mutation.addedNodes[i].className == 'video-wrapper') {
  1998. vimeo_run(mutation.addedNodes);
  1999. break;
  2000. }
  2001. }
  2002. }
  2003. });
  2004. });
  2005. observer.observe(content, {childList: true, subtree: true});
  2006. } else {
  2007. page.win.setInterval(function() {
  2008. nurl = window.location.href;
  2009. if (page.url != nurl) vimeo_run(); //window.location.href = nurl;
  2010. }, 500)
  2011. }
  2012.  
  2013. }
  2014.  
  2015. // VEVO
  2016. else if (page.url.match(/https?:\/\/(www\.)?vevo.com\//)) {
  2017. var oldurl;
  2018. var vePlayerWindow;
  2019. var ve1PlayerWindow;
  2020. var veVideoThumb;
  2021.  
  2022. function vevo_run(vePlayerId) {
  2023. var PlayerHeight, PlayerWidth, PlayerWideHeight, PlayerWideWidth, veVideo, myVideoCode;
  2024. if (oldurl == page.url) return;
  2025. oldurl = page.url;
  2026.  
  2027. function createMyvePlayer() {
  2028. try {window.removeEventListener('resize', vePlayerResize, false)} catch(e) {};
  2029. var veDefaultVideo = 'Standard Definition MP4';
  2030. var player = {
  2031. 'panelHeight': 22,
  2032. 'playerSocket': vePlayerWindow,
  2033. 'playerWindow': myPlayerWindow,
  2034. 'videoList': veVideoList,
  2035. 'videoPlay': veDefaultVideo,
  2036. 'videoThumb': veVideoThumb,
  2037. 'videoDuration': veVideoDuration,
  2038. 'playerWidth': PlayerWidth,
  2039. 'playerHeight': PlayerHeight
  2040. };
  2041.  
  2042. vePlayerResize = function () {
  2043. veSizes();
  2044. player['playerWidth'] = PlayerWidth;
  2045. player['playerHeight'] = PlayerHeight;
  2046. player['playerWideWidth'] = PlayerWideWidth;
  2047. player['playerWideHeight'] = PlayerWideHeight;
  2048. var veInfoWindow = getMyElement ('', 'div', 'class', 'watch-info', 0, false);
  2049. if (veInfoWindow) styleMyElement (veInfoWindow, {position: 'absolute', top: '0px', left: Math.floor(PlayerWidth + 1) + 'px'});
  2050. resizeMyPlayer(player, 'widesize');
  2051. };
  2052.  
  2053. feature['container'] = false;
  2054. feature['widesize'] = false;
  2055. option['definitions'] = ['Ultra High Definition', 'Full High Definition', 'High Definition', 'Standard Definition', 'Low Definition', 'Very Low Definition'];
  2056. option['containers'] = ['MP4'];
  2057. HeadWindow = getMyElement('', 'div', 'class', 'header-content', 0, false);
  2058. createMyPlayer (player);
  2059.  
  2060. /* Update Sizes */
  2061. window.addEventListener('resize', vePlayerResize,false);
  2062. }
  2063.  
  2064. function veSizes(MyWindow) {
  2065. var veScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
  2066. var veScreenHeight = page.win.innerHeight || page.doc.documentElement.clientHeight;
  2067. PlayerWidth = MyWindow.clientWidth;
  2068. PlayerHeight = MyWindow.clientHeight;
  2069. PlayerWideWidth = MyWindow.clientWidth;
  2070. PlayerWideHeight = MyWindow.clientHeight;
  2071. }
  2072.  
  2073. var veVideoFormats = {
  2074. 'High': 'High Definition MP4'
  2075. ,'Med': 'Standard Definition MP4'
  2076. ,'Low': 'Ultra Low Definition MP4'
  2077. ,'HTTP Live Streaming': 'HTTP Live Streaming'
  2078. ,'564000': 'Very Low Definition MP4'
  2079. ,'864000': 'Low Definition MP4'
  2080. ,'1328000':'Standard Definition MP4'
  2081. ,'1728000':'Standard Definition HBR MP4'
  2082. ,'2528000':'High Definition MP4'
  2083. ,'3328000':'High Definition HBR MP4'
  2084. ,'4392000':'Full High Definition MP4'
  2085. ,'4328000':'Full High Definition MP4'
  2086. ,'5392000':'Full High Definition HBR MP4'
  2087. ,'5328000':'Full High Definition HBR MP4'
  2088. };
  2089. var veVideoList = {};
  2090. var veVideoFound1 = false;
  2091. var veVideoFound2 = false;
  2092.  
  2093. /* Get Player Window */
  2094. vePlayerWindow = getMyElement ('', 'div', 'class', 'banner-notPresent', 0, false);
  2095. if (!vePlayerWindow) vePlayerWindow = getMyElement ('', 'div', 'class', 'hero', 0, false);
  2096. if (!vePlayerWindow) {
  2097. showMyMessage ('!player');
  2098. }
  2099. else {
  2100. /* Get Videos Content */
  2101. var veVideoID = page.url.match(/((https?:\/\/(www\.)?vevo.com\/watch.*\/)|(vevo:))(\w{10,12})(\?|$)/);
  2102. veVideoID = veVideoID ? veVideoID[5] : null;
  2103. if (!veVideoID) veVideoID = getMyContent(page.url,'"embedURL" href=.*?videoId=(.*?)\&amp;',false);
  2104. var veVideoPlayer = getMyContent(page.url, 'meta\\s+property="og:video"\\s+content="(.*?)"', false);
  2105. var xmlHTTP = new XMLHttpRequest();
  2106. xmlHTTP.open('POST', 'https://www.vevo.com/auth', false);
  2107. xmlHTTP.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
  2108. xmlHTTP.send();
  2109. var vevotoken = xmlHTTP.responseText.match(/"access_token"\s*:\s*"(.*?)"/);
  2110.  
  2111. var veVideoURL = "https://apiv2.vevo.com/video/" + veVideoID + "?token=" + vevotoken[1];
  2112. getMyContentGM(veVideoURL, 'TEXT', false, function(veVideosContent) {
  2113. if (veVideosContent) {
  2114. var veVideosJSON = JSON.parse(veVideosContent);
  2115. veVideoThumb = veVideosContent.match('"thumbnailUrl":"(.*?)"')
  2116. if (veVideoThumb) veVideoThumb = veVideoThumb[1];
  2117. }
  2118. else {
  2119. showMyMessage ('!content');
  2120. }
  2121.  
  2122. cleanMyElement (vePlayerWindow, false);
  2123.  
  2124. /* My Player Window */
  2125. veSizes(vePlayerWindow);
  2126.  
  2127. if (myPlayerWindow) {
  2128. modifyMyElement (myPlayerWindow, 'div', '', true);
  2129. } else {
  2130. var vePlayer = getMyElement(vePlayerWindow, 'div', 'class', 'flash-player', 0, false);
  2131. if (!vePlayer) vePlayer = getMyElement ('', 'div', 'id', 'freewheel-container', -1, false);
  2132. if (vePlayer) {
  2133. removeMyElement(vePlayer.parentNode, vePlayer);
  2134. modifyMyElement (vePlayer, 'div', '', true);
  2135. styleMyElement (vePlayer, {display: 'none'});
  2136. }
  2137. myPlayerWindow = createMyElement ('div', '', '', '', '');
  2138. styleMyElement (myPlayerWindow, {position: 'relative', width: PlayerWidth + 'px', height: PlayerHeight + 'px', backgroundColor: '#F4F4F4', zIndex: '18',fontFamily: '"Arial","Helvetica","sans-serif"', margin: '0 auto'});
  2139. var vePlayerError = getMyElement ('', 'div', 'class', 'video-error', 0, false);
  2140. if (vePlayerError) {
  2141. removeMyElement(vePlayerError.parentNode, vePlayerError);
  2142. }
  2143. var veVideoPoster = getMyElement ('', 'div', 'class', 'videoPoster', 0, false);
  2144. if (veVideoPoster) {
  2145. removeMyElement(veVideoPoster.parentNode, veVideoPoster);
  2146. }
  2147. appendMyElement (vePlayerWindow, myPlayerWindow);
  2148. // var veInfoWindow = getMyElement ('', 'div', 'class', 'watch-info', 0, false);
  2149. // if (veInfoWindow) styleMyElement (veInfoWindow, {position: 'absolute', top: '0px', left: Math.floor(PlayerWidth + 1) + 'px'});
  2150. }
  2151.  
  2152. if (veVideosJSON) {
  2153. var veStreamURL = "https://apiv2.vevo.com/video/" + veVideoID + "/streams?token=" + vevotoken[1];
  2154. veVideosJSON.video = {Object};
  2155. getMyContentGM(veStreamURL,'TEXT', false, function (veVideosContent) {
  2156. veVideosJSON.video.videoVersions = JSON.parse(veVideosContent);
  2157. var veVideo, veVideoVersion;
  2158. for (var i = 0; i < veVideosJSON.video.videoVersions.length - 1; i++) {
  2159. if (veVideosJSON.video.videoVersions[i].sourceType == 2) {
  2160. if (veVideosJSON.video.videoVersions[i].version in {3:1,4:1}) {
  2161. for (var veVideoFormat in veVideoFormats) {
  2162. veVideo = veVideosJSON.video.videoVersions[i].data.match('rendition name="' + veVideoFormat + '" url="(.*?)"');
  2163. if (veVideo) {
  2164. veVideoFound1 = true;
  2165. veVideoList[veVideoFormats[veVideoFormat]] = veVideo[1];
  2166. }
  2167. }
  2168. }
  2169. }
  2170. if (veVideoFound1) break;
  2171. }
  2172. for (var i = 0; i < veVideosJSON.video.videoVersions.length - 1; i++) {
  2173. if (veVideosJSON.video.videoVersions[i].sourceType == 3) {
  2174. for (var veVideoFormat in veVideoFormats) {
  2175. veVideo = veVideosJSON.video.videoVersions[i].data.match('rendition name="' + veVideoFormat + '" url="(.*?)"');
  2176. if (veVideo) {
  2177. veVideoFound1 = true;
  2178. veVideoFound2 = true;
  2179. veVideoList[veVideoFormats[veVideoFormat] + ' MP4'] = veVideo[1];
  2180. }
  2181. }
  2182. }
  2183. if (veVideoFound2) break;
  2184. }
  2185. veVideoFound2 = false;
  2186. for (var i = 0; i < veVideosJSON.video.videoVersions.length - 1; i++) {
  2187. if (veVideosJSON.video.videoVersions[i].url && veVideosJSON.video.videoVersions[i].url.match('//h264-((lvl3)|(aws)).vevo.com/')) {
  2188. for (var veVideoFormat in veVideoFormats) {
  2189. if (veVideosJSON.video.videoVersions[i].quality == veVideoFormat) {
  2190. veVideoFound1 = true;
  2191. veVideoFound2 = true;
  2192. veVideoList[veVideoFormats[veVideoFormat]] = veVideosJSON.video.videoVersions[i].url;
  2193. }
  2194. }
  2195. }
  2196. }
  2197. veVideoFound2 = false;
  2198. for (var i = 0; i < veVideosJSON.video.videoVersions.length - 1; i++) {
  2199. if (veVideosJSON.video.videoVersions[i].url && veVideosJSON.video.videoVersions[i].url.match('//hls-((lvl3)|(aws)|(aka)).vevo.com/')) {
  2200. veVideoFound1 = true;
  2201. veVideoFound2 = true;
  2202. veVideoList[veVideoFormats['HTTP Live Streaming']] = veVideosJSON.video.videoVersions[i].url;
  2203. }
  2204. }
  2205. veVideoFound2 = false;
  2206. for (var i = 0; i < veVideosJSON.video.videoVersions.length - 1; i++) {
  2207. if (veVideosJSON.video.videoVersions[i].sourceType == 5 && veVideosJSON.video.videoVersions[i].version == 1) {
  2208. veVideo = veVideosJSON.video.videoVersions[i].data.match('rendition name="HTTP\\s?Level3" url="(.*?)"');
  2209. if (veVideo) veVideoFound2 = true;
  2210. }
  2211. else if (veVideosJSON.video.videoVersions[i].url && veVideosJSON.video.videoVersions[i].url.match('//smil-((lvl3)|(aws)|(aka)).vevo.com/')) {
  2212. veVideo = veVideosJSON.video.videoVersions[i].url
  2213. if (veVideo) veVideoFound2 = true;
  2214. }
  2215. if (veVideoFound2) break;
  2216. }
  2217. if (veVideoFound2) getMyContentGM(veVideo[1],'TEXT',false, function (vesmilfile) {
  2218. for (veVideoFormat in veVideoFormats) {
  2219. if (vesmilfile.match(veVideoFormat)) {
  2220. veVideoList[veVideoFormats[veVideoFormat]] = "http://smil.lvl3.vevo.com" + vesmilfile.match('video src="mp4:(.*?)" system-bitrate="' + veVideoFormat + '"')[1];
  2221. }
  2222. }
  2223. createMyvePlayer();
  2224. });
  2225. if (!veVideoFound2) if (veVideoFound1) createMyvePlayer(); else showMyMessage ('!videos');
  2226. });
  2227. }
  2228. });
  2229. }
  2230. }
  2231.  
  2232. function start_vevo() {
  2233. var elWait = 50;
  2234. var refreshIntervalId = page.win.setInterval(function() {
  2235. if (getMyElement('', 'div', 'class', 'flash-player', 0, false) || getMyElement ('', 'div', 'id', 'html5-player', -1, false)
  2236. || getMyElement ('', 'div', 'class', 'video-error', 0, false)) {
  2237. page.win.clearInterval(refreshIntervalId);
  2238. page = {win: window, doc: document, body: document.body, url: window.location.href}
  2239. vevo_run();
  2240. } else if (elWait > 0) {
  2241. elWait--;
  2242. } else {
  2243. page.win.clearInterval(refreshIntervalId);
  2244. }
  2245. }, 500);
  2246. }
  2247.  
  2248. start_vevo();
  2249. var oId = getMyContent(page.url,'"embedURL" href=.*?isrc=(.*?)\&amp;',false);
  2250. var nId;
  2251. page.win.setInterval(function() {
  2252. nId = getMyContent(page.url,'"embedURL" href=.*?isrc=(.*?)\&amp;',false);
  2253. if (nId != oId) {
  2254. oId = nId;
  2255. page.url = window.location.href;
  2256. if (getMyElement ('', 'div', 'class', 'watch-info', 0, false)) vevo_run(); else window.location.href = page.url;
  2257. }
  2258. }, 500)
  2259.  
  2260. }
  2261.  
  2262. // =====MetaCafe===== //
  2263.  
  2264. else if (page.url.indexOf('metacafe.com/watch') != -1) {
  2265. /* Get Player Window */
  2266. var mcPlayerWindow = getMyElement('', 'div', 'class', 'mc-player-wrap', 0, false);
  2267. if (!mcPlayerWindow) {
  2268. showMyMessage ('!player');
  2269. }
  2270. else {
  2271. /* Get Video Thumbnail */
  2272. var mcVideoThumb = getMyContent (page.url, '"preview":"(.*?)"', true);
  2273. var mcVideoDuration = getMyContent (page.url, '\\("duration","(.*?)"\\)', false)
  2274. if (mcVideoDuration) mcVideoDuration = 60 * parseInt(mcVideoDuration) + parseInt(mcVideoDuration.split('-')[1]);
  2275.  
  2276. /* Get Videos Content */
  2277. var mcVideosContent = getMyContent(page.url, 'var flashvars\\s*=\\s*({.*?});', false);
  2278.  
  2279. /* Player Size */
  2280. var mcPlayerWidth, mcPlayerHeight, mcPlayerWideWidth, mcPlayerWideHeight;
  2281. function mcGetSizes() {
  2282. mcPlayerWidth = mcPlayerWindow.clientWidth;
  2283. mcPlayerHeight = Math.ceil(mcPlayerWidth / (16 / 9)) + 22;
  2284. mcPlayerWideWidth = mcPlayerHeight + 150;
  2285. mcPlayerWideHeight = Math.ceil(mcPlayerWideWidth / (16 / 9)) + 22;
  2286. }
  2287. function mcUpdateSizes() {
  2288. mcGetSizes();
  2289. player['playerWidth'] = mcPlayerWidth;
  2290. player['playerHeight'] = mcPlayerHeight;
  2291. resizeMyPlayer('widesize');
  2292. }
  2293. mcGetSizes();
  2294.  
  2295. /* My Player Window */
  2296. myPlayerWindow = createMyElement ('div', '', '', '', '');
  2297. styleMyElement (myPlayerWindow, {position: 'relative', width: mcPlayerWidth + 'px', height: mcPlayerHeight + 'px', backgroundColor: '#F4F4F4', zIndex: '10'});
  2298. styleMyElement(getMyElement('', 'div', 'class', 'mc-player', 0, false), {display: 'none'});
  2299. styleMyElement (mcPlayerWindow, {height: '100%'});
  2300. appendMyElement(mcPlayerWindow, myPlayerWindow);
  2301.  
  2302. /* Resize Event */
  2303. page.win.addEventListener('resize', mcUpdateSizes, false);
  2304.  
  2305. /* Hide Ads */
  2306. var mcTopAd = getMyElement('', 'div', 'id', 'spot_header', -1, false);
  2307. if (mcTopAd && mcTopAd.parentNode && mcTopAd.parentNode.parentNode) removeMyElement(mcTopAd.parentNode.parentNode, mcTopAd.parentNode);
  2308. var mcRightAd = getMyElement('', 'div', 'id', 'spot_right_top', -1, false);
  2309. if (mcRightAd && mcRightAd.parentNode && mcRightAd.parentNode.parentNode) removeMyElement(mcRightAd.parentNode.parentNode, mcRightAd.parentNode);
  2310.  
  2311. blockObject = mcPlayerWindow;
  2312.  
  2313. /* Get Videos */
  2314. if (mcVideosContent) {
  2315. var mcVideoList = {};
  2316. var mcVideoFound = false;
  2317. var mcVideoFormats = {'video_alt_url2': 'High Definition MP4', 'video_alt_url': 'Low Definition MP4', 'video_url': 'Very Low Def MP4'};
  2318. var mcVideoFormatz = {'video_alt_url2': '_720p', 'video_alt_url': '_360p', 'video_url': '_240p'};
  2319. var mcVideoHLS = mcVideosContent.match (/"src":"(.*?)"/);
  2320. mcVideoHLS = (mcVideoHLS) ? cleanMyContent(mcVideoHLS[1], false) : null;
  2321. if (mcVideoHLS) {
  2322. var mcVideoParser, mcVideoParse, myVideoCode, mcVideo, mcDefaultVideo;
  2323. for (var mcVideoCode in mcVideoFormats) {
  2324. mcVideoParser = '"' + mcVideoCode + '":"(.*?)"';
  2325. mcVideoParse = mcVideosContent.match (mcVideoParser);
  2326. mcVideo = (mcVideoParse) ? mcVideoParse[1] : null;
  2327. if (mcVideo) {
  2328. if (!mcVideoFound) mcVideoFound = true;
  2329. myVideoCode = mcVideoFormats[mcVideoCode];
  2330. mcVideoList[myVideoCode] = mcVideoHLS.replace('.m3u8', mcVideoFormatz[mcVideoCode] + '.m3u8');
  2331. if (!mcDefaultVideo) mcDefaultVideo = myVideoCode
  2332. }
  2333. }
  2334. }
  2335.  
  2336. if (mcVideoFound) {
  2337. /* Get Watch Sidebar */
  2338. var mcSidebarWindow = getMyElement ('', 'div', 'class', 'mc-right-block', 0, false);
  2339.  
  2340. /* Create Player */
  2341. var player = {
  2342. 'panelHeight': 22,
  2343. 'playerSocket': mcPlayerWindow,
  2344. 'playerWindow': myPlayerWindow,
  2345. 'videoList': mcVideoList,
  2346. 'videoPlay': mcDefaultVideo,
  2347. 'videoThumb': mcVideoThumb,
  2348. 'videoDuration': mcVideoDuration,
  2349. 'playerWidth': mcPlayerWidth,
  2350. 'playerHeight': mcPlayerHeight,
  2351. 'playerWideWidth': 1140,
  2352. 'playerWideHeight': 672,
  2353. 'sidebarWindow': mcSidebarWindow,
  2354. 'sidebarMarginNormal': 0,
  2355. 'sidebarMarginWide': 466
  2356. };
  2357. feature['container'] = false;
  2358. feature['widesize'] = false;
  2359. option['definitions'] = ['High Definition', 'Low Definition', 'Very Low Definition'];
  2360. option['containers'] = ['MP4', 'Any'];
  2361. HeadWindow = getMyElement ('', 'div', 'id', 'mc-header', -1, false);
  2362. createMyPlayer (player);
  2363. }
  2364. else {
  2365. showMyMessage ('!videos');
  2366. }
  2367. }
  2368. else {
  2369. var ytVideoId = page.url.match (/\/yt-(.*?)\//);
  2370. if (ytVideoId && ytVideoId[1]) {
  2371. var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId[1];
  2372. showMyMessage ('embed', ytVideoLink);
  2373. }
  2374. else {
  2375. showMyMessage ('!content');
  2376. }
  2377. }
  2378. }
  2379. }
  2380.  
  2381. // =====Break===== //
  2382.  
  2383. else if (page.url.indexOf('break.com/video') != -1 || page.url.indexOf('break.com/movies') != -1) {
  2384.  
  2385. /* Get Player Window */
  2386. var brPlayerWindow = getMyElement ('', 'div', 'id', 'video-player', -1, false);
  2387. if (!brPlayerWindow) {
  2388. showMyMessage ('!player');
  2389. }
  2390. else {
  2391. /* Get Video ID */
  2392. var brVideoID = page.url.match(/-(\d+)($|\?)/);
  2393. brVideoID = (brVideoID) ? brVideoID[1] : null;
  2394.  
  2395. /* Get Videos Content */
  2396. var brSource = page.win.location.protocol + '//' + page.win.location.hostname + '/embed/' + brVideoID;
  2397. var brVideosContent = getMyContent (brSource, 'TEXT', false);
  2398.  
  2399. /* Player Size */
  2400. var brScreenWidth;
  2401. var brPlayerWidth, brPlayerHeight;
  2402. var brPlayerWideWidth, brPlayerWideHeight;
  2403. var brSidebarMarginWide = 720;
  2404. function brSizes() {
  2405. brScreenWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
  2406. brPlayerWidth = brPlayerWindow.clientWidth;
  2407. brPlayerHeight = brPlayerWindow.clientHeight;
  2408. }
  2409. brSizes();
  2410.  
  2411. /* My Player Window */
  2412. myPlayerWindow = createMyElement ('div', '', '', '', '');
  2413. styleMyElement (myPlayerWindow, {position: 'relative', width: brPlayerWidth + 'px', height: brPlayerHeight + 'px', backgroundColor: '#F4F4F4'});
  2414. modifyMyElement (brPlayerWindow, 'div', '', true);
  2415. styleMyElement (brPlayerWindow, {height: brPlayerHeight + 'px', overflow: 'visible', paddingBottom: '0px'});
  2416. appendMyElement (brPlayerWindow, myPlayerWindow);
  2417.  
  2418. /* Update Sizes */
  2419. page.win.addEventListener('resize', function() {
  2420. brSizes();
  2421. player['playerWidth'] = brPlayerWidth;
  2422. player['playerHeight'] = brPlayerHeight;
  2423. player['playerWideWidth'] = brPlayerWideWidth;
  2424. player['playerWideHeight'] = brPlayerWideHeight;
  2425. player['sidebarMarginWide'] = brSidebarMarginWide;
  2426. resizeMyPlayer('widesize');
  2427. }, false);
  2428.  
  2429. /* Get Videos */
  2430. if (brVideosContent) {
  2431. var brVideoList = {};
  2432. var brVideoFormats = {};
  2433. var brVideoFound = false;
  2434. 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'};
  2435. var brVideoPath, brVideoToken, brVideoThumb, brVideo, myVideoCode;
  2436. if (page.url.indexOf('break.com/video') != -1) {
  2437. brVideoPath = brVideosContent.match (/"videoUri":\s"(.*?)496_kbps/);
  2438. brVideoPath = (brVideoPath) ? brVideoPath[1] : null;
  2439. }
  2440. else {
  2441. brVideoPath = brVideosContent.match (/"hlsUri":\s"(.*?)"/);
  2442. brVideoPath = (brVideoPath) ? brVideoPath[1] : null;
  2443. }
  2444. brVideoToken = brVideosContent.match (/"AuthToken":\s"(.*?)"/);
  2445. brVideoToken = (brVideoToken) ? brVideoToken[1] : null;
  2446. brVideoThumb = brVideosContent.match (/"thumbUri":\s"(.*?)"/);
  2447. brVideoThumb = (brVideoThumb) ? brVideoThumb[1] : null;
  2448. if (brVideoPath && brVideoToken) {
  2449. for (var brVideoCode in brVideoFormats) {
  2450. if (brVideosContent.match(brVideoCode)) {
  2451. if (!brVideoFound) brVideoFound = true;
  2452. myVideoCode = brVideoFormats[brVideoCode];
  2453. if (page.url.indexOf('break.com/video') != -1) brVideo = brVideoPath + brVideoCode + '?' + brVideoToken;
  2454. else brVideo = brVideoPath + brVideoCode + '.m3u8?' + brVideoToken;
  2455. brVideoList[myVideoCode] = brVideo;
  2456. }
  2457. }
  2458. }
  2459.  
  2460. if (brVideoFound) {
  2461. /* Get Watch Sidebar */
  2462. var brSidebarWindow = getMyElement ('', 'aside', 'class', 'sidebar', 0, false);
  2463.  
  2464. /* Create Player */
  2465. var brDefaultVideo = 'Low Definition MP4';
  2466. var brWindowWidth = page.win.innerWidth || page.doc.documentElement.clientWidth;
  2467. player = {
  2468. 'panelHeight': 26,
  2469. 'panelPadding': -2,
  2470. 'playerSocket': brPlayerWindow,
  2471. 'playerWindow': myPlayerWindow,
  2472. 'videoList': brVideoList,
  2473. 'videoPlay': brDefaultVideo,
  2474. 'videoThumb': brVideoThumb,
  2475. 'playerWidth': brPlayerWidth,
  2476. 'playerHeight': brPlayerHeight,
  2477. 'sidebarWindow': brSidebarWindow,
  2478. 'sidebarMarginNormal': 10
  2479. };
  2480. feature['widesize'] = false;
  2481. HeadWindow = getMyElement('', 'div', 'class', 'SiteNav', 0, false);
  2482. option['definitions'] = ['Very Low Definition', 'Low Definition', 'Standard Definition', 'High Definition', 'Full High Definition'];
  2483. option['containers'] = ['MP4', 'FLV', 'Any'];
  2484. createMyPlayer (player);
  2485. }
  2486. else {
  2487. var ytVideoId = brVideosContent.match (/"youtubeId":\s"(.*?)"/);
  2488. if (ytVideoId && ytVideoId[1]) {
  2489. var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId[1];
  2490. showMyMessage ('embed', ytVideoLink);
  2491. }
  2492. else {
  2493. showMyMessage ('!videos');
  2494. }
  2495. }
  2496. }
  2497. else {
  2498. showMyMessage ('!content');
  2499. }
  2500. }
  2501. }
  2502.  
  2503. // =====FunnyOrDie===== //
  2504. else if (page.url.indexOf('funnyordie.com/videos') != -1) {
  2505.  
  2506. function fod_run() {
  2507. /* Get Player Window */
  2508. var fodPlayerWindow = getMyElement ('', 'div', 'id', 'videoContainer', -1, false);
  2509. if (!fodPlayerWindow) {
  2510. showMyMessage ('!player');
  2511. }
  2512. else {
  2513. /* Get Video Thumbnail */
  2514. var fodVideoThumb = getMyContent (page.url, 'meta\\s+property="og:image"\\s+content="(.*?)"', false);
  2515. if (fodVideoThumb) fodVideoThumb = fodVideoThumb.replace (/large/, 'fullsize');
  2516.  
  2517. /* Get Videos Content */
  2518. var fodVideosContent = getMyContent (page.url, '<video([\\s\\S]*?)video>', false);
  2519.  
  2520. /* Clean Player Window */
  2521. var fodPlayerContainer = getMyElement ('', 'div', 'id', 'videoContainer', -1, false);
  2522. var PlayerHeight = fodPlayerContainer.clientHeight + 22;
  2523. var PlayerWidth = fodPlayerContainer.clientWidth;
  2524. if (fodPlayerContainer) styleMyElement (fodPlayerContainer, {display: 'none'});
  2525. blockObject = fodPlayerContainer;
  2526.  
  2527. /* My Player Window */
  2528. myPlayerWindow = createMyElement ('div', '', '', '', '');
  2529. styleMyElement (myPlayerWindow, {position: 'relative', width: PlayerWidth + 'px', height: PlayerHeight + 'px', backgroundColor: '#F4F4F4', margin: '0px auto'});
  2530. styleMyElement (fodPlayerWindow, {height: '100%', overflow: 'visible'});
  2531. fodPlayerContainer.parentNode.insertBefore (myPlayerWindow, fodPlayerContainer);
  2532.  
  2533. /* Get Videos */
  2534. if (fodVideosContent) {
  2535. 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'};
  2536. var fodVideoList = {};
  2537. var fodVideoFound = false;
  2538. var fodVideoPath, fodVideoCodes, fodVideo, myVideoCode;
  2539. fodVideoPath = fodVideosContent.match(/src="(.*?)v\d+.*?\.mp4"/);
  2540. fodVideoPath = (fodVideoPath) ? fodVideoPath[1] : null;
  2541. fodVideoCodes = fodVideosContent.match (/v([^\/]*?)\/master/)
  2542. if (!fodVideoCodes) fodVideoCodes = fodVideosContent.match (/src=".*?\/v(\d{3,4})\./);
  2543. fodVideoCodes = (fodVideoCodes) ? fodVideoCodes[1] : '';
  2544. if (fodVideoPath && fodVideoCodes) {
  2545. for (var fodVideoCode in fodVideoFormats) {
  2546. if (fodVideoCodes.indexOf(fodVideoCode.replace(/v/, '').replace(/\..*/, "")) != -1) {
  2547. if (!fodVideoFound) fodVideoFound = true;
  2548. fodVideo = page.win.location.protocol + fodVideoPath + fodVideoCode;
  2549. myVideoCode = fodVideoFormats[fodVideoCode];
  2550. fodVideoList[myVideoCode] = fodVideo;
  2551. }
  2552. }
  2553. }
  2554. else {
  2555. for (var fodVideoCode in fodVideoFormats) {
  2556. fodVideo = page.win.location.protocol + fodVideoPath + fodVideoCode;
  2557. if (fodVideosContent.match(fodVideo)) {
  2558. if (!fodVideoFound) fodVideoFound = true;
  2559. myVideoCode = fodVideoFormats[fodVideoCode];
  2560. fodVideoList[myVideoCode] = fodVideo;
  2561. }
  2562. }
  2563. }
  2564.  
  2565. if (fodVideoFound) {
  2566. /* Create Player */
  2567. fodDefaultVideo = 'Low Definition MP4';
  2568. var player = {
  2569. 'playerSocket': fodPlayerWindow,
  2570. 'playerWindow': myPlayerWindow,
  2571. 'videoList': fodVideoList,
  2572. 'videoPlay': fodDefaultVideo,
  2573. 'videoThumb': fodVideoThumb,
  2574. 'playerWidth': PlayerWidth,
  2575. 'playerHeight': PlayerHeight
  2576. };
  2577. feature['container'] = false;
  2578. feature['widesize'] = false;
  2579. option['definitions'] = ['High Definition', 'Low Definition'];
  2580. option['containers'] = ['MP4'];
  2581. createMyPlayer (player);
  2582. styleMyElement (player['playerPanel'], {height: '24px'});
  2583. }
  2584. else {
  2585. showMyMessage ('!videos');
  2586. }
  2587. }
  2588. else {
  2589. showMyMessage ('!content');
  2590. }
  2591. }
  2592. }
  2593.  
  2594. fod_run()
  2595. var oId = window.location.href;
  2596. var nId;
  2597. page.win.setInterval(function() {
  2598. nId = window.location.href;
  2599. if (nId != oId) {
  2600. oId = nId;
  2601. page.url = window.location.href;
  2602. window.location.href = page.url;
  2603. }
  2604. }, 500)
  2605. }
  2606.  
  2607. // =====Veoh===== //
  2608. else if (page.url.indexOf('veoh.com/watch') != -1) {
  2609.  
  2610. /* Get Video Availability */
  2611. if (getMyElement ('', 'div', 'class', 'veoh-video-player-error', 0, false)) return;
  2612.  
  2613. /* Get Player Window */
  2614. var vePlayerWindow = getMyElement ('', 'div', 'id', 'videoPlayerContainer', -1, false);
  2615. if (!vePlayerWindow) {
  2616. showMyMessage ('!player');
  2617. }
  2618. else {
  2619. /* Get Videos Content */
  2620. var veVideosContent = getMyContent (page.url, '__watch.videoDetailsJSON = \'\\{(.*?)\\}\'', false);
  2621. veVideosContent = cleanMyContent (veVideosContent, true);
  2622.  
  2623. /* Get Video Thumbnail */
  2624. var veVideoThumbGet = veVideosContent.match (/"highResImage":"(.*?)"/);
  2625. var veVideoThumb = (veVideoThumbGet) ? veVideoThumbGet[1] : null;
  2626. var veVideoDuration = getMyContent (page.url, 'meta\\s+name="item-duration"\\s+content="(.*?)"', false);
  2627. if (veVideoDuration) veVideoDuration = parseInt(veVideoDuration);
  2628.  
  2629. /* My Player Window */
  2630. var myPlayerWindow = createMyElement ('div', '', '', '', '');
  2631. styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '382px', backgroundColor: '#F4F4F4', zIndex: '99999'});
  2632. modifyMyElement (vePlayerWindow, 'div', '', true);
  2633. styleMyElement (vePlayerWindow, {height: '100%'});
  2634. appendMyElement (vePlayerWindow, myPlayerWindow);
  2635.  
  2636. /* Get Videos */
  2637. if (veVideosContent) {
  2638. var veVideoFormats = {'fullPreviewHashLowPath': 'Very Low Definition MP4', 'fullPreviewHashHighPath': 'Low Definition MP4'};
  2639. var veVideoList = {};
  2640. var veVideoFound = false;
  2641. var veVideoParser, veVideoParse, veVideo, myVideoCode;
  2642. for (var veVideoCode in veVideoFormats) {
  2643. veVideoParser = veVideoCode + '":"(.*?)"';
  2644. veVideoParse = veVideosContent.match (veVideoParser);
  2645. veVideo = (veVideoParse) ? veVideoParse[1] : null;
  2646. if (veVideo) {
  2647. if (!veVideoFound) veVideoFound = true;
  2648. myVideoCode = veVideoFormats[veVideoCode];
  2649. veVideoList[myVideoCode] = veVideo;
  2650. }
  2651. }
  2652.  
  2653. if (veVideoFound) {
  2654. /* Get Watch Sidebar */
  2655. var veSidebarWindow = getMyElement ('', 'div', 'id', 'videoToolsContainer', -1, false);
  2656. if (veSidebarWindow) styleMyElement(veSidebarWindow, {marginTop: '-380px'});
  2657.  
  2658. /* Create Player */
  2659. var veDefaultVideo = 'Low Definition MP4';
  2660. var player = {
  2661. 'playerSocket': vePlayerWindow,
  2662. 'playerWindow': myPlayerWindow,
  2663. 'videoList': veVideoList,
  2664. 'videoPlay': veDefaultVideo,
  2665. 'videoThumb': veVideoThumb,
  2666. 'videoDuration': veVideoDuration,
  2667. 'playerWidth': 640,
  2668. 'playerHeight': 382,
  2669. 'playerWideWidth': 970,
  2670. 'playerWideHeight': 568,
  2671. 'sidebarWindow': veSidebarWindow,
  2672. 'sidebarMarginNormal': -380,
  2673. 'sidebarMarginWide': 20
  2674. };
  2675. feature['container'] = false;
  2676. option['definition'] = 'LD';
  2677. option['definitions'] = ['Low Definition', 'Very Low Definition'];
  2678. option['containers'] = ['MP4'];
  2679. createMyPlayer (player);
  2680. }
  2681. else {
  2682. var veVideoSource = getMyContent(page.url, '"videoContentSource":"(.*?)"', false);
  2683. if (veVideoSource == 'YouTube') var ytVideoId = getMyContent(page.url, '"videoId":"yapi-(.*?)"', false);
  2684. if (ytVideoId) {
  2685. var ytVideoLink = 'http://youtube.com/watch?v=' + ytVideoId;
  2686. showMyMessage ('embed', ytVideoLink);
  2687. }
  2688. else {
  2689. showMyMessage ('!videos');
  2690. }
  2691. }
  2692. }
  2693. else {
  2694. showMyMessage ('!content');
  2695. }
  2696. }
  2697.  
  2698. }
  2699.  
  2700. // =====Viki===== //
  2701.  
  2702. else if (page.url.indexOf('viki.com/videos') != -1) {
  2703.  
  2704. /* Get Player Window */
  2705. var vkPlayerWindow = getMyElement ('', 'div', 'class', 'video-placeholder', 0, false);
  2706.  
  2707. if (!vkPlayerWindow) {
  2708. showMyMessage ('!player');
  2709. }
  2710. else {
  2711. /* Get Video ID */
  2712. var vkVideoID = page.url.match(/videos\/(.*?)v/);
  2713. vkVideoID = (vkVideoID) ? vkVideoID[1] : null;
  2714.  
  2715. /* Get Videos Content */
  2716. var vkVideosContent;
  2717. if (vkVideoID) vkVideosContent = getMyContent (page.win.location.protocol + '//' + page.win.location.host + '/player5_fragment/' + vkVideoID + 'v.json', 'TEXT', false);
  2718. var vkVideoDuration = getMyContent(page.url, '"duration":(.*?),', false);
  2719.  
  2720. /* Player Size */
  2721. var vkSidebarWidth = 320;
  2722. var vkSidebarWindow = getMyElement ('', 'div', 'class', 'col s12 l4 right', 0, false);
  2723. var vkPlayerWidth, vkPlayerHeight;
  2724. var vkPlayerWideWidth, vkPlayerWideHeight;
  2725. var vkSidebarMarginWide;
  2726. function vkGetSizes() {
  2727. vkPlayerWidth = vkPlayerWindow.clientWidth + 2;
  2728. vkPlayerHeight = Math.ceil(vkPlayerWidth / (16 / 9)) + 22;
  2729. vkSidebarWidth = vkSidebarWindow.clientWidth;
  2730. vkPlayerWideWidth = vkPlayerWidth + vkSidebarWidth;
  2731. vkPlayerWideHeight = Math.ceil(vkPlayerWideWidth / (16 / 9)) + 22;
  2732. vkSidebarMarginWide = vkPlayerWideHeight + 20;
  2733. }
  2734. function vkUpdateSizes() {
  2735. vkGetSizes();
  2736. player['playerWidth'] = vkPlayerWidth;
  2737. player['playerHeight'] = vkPlayerHeight;
  2738. player['playerWideWidth'] = vkPlayerWideWidth;
  2739. player['playerWideHeight'] = vkPlayerWideHeight;
  2740. player['sidebarMarginWide'] = vkSidebarMarginWide;
  2741. resizeMyPlayer(player, 'widesize');
  2742. }
  2743. vkGetSizes();
  2744.  
  2745. /* My Player Window */
  2746. var myPlayerWindow = createMyElement ('div', '', '', '', '');
  2747. styleMyElement (myPlayerWindow, {position: 'relative', width: vkPlayerWidth + 'px', height: vkPlayerHeight + 'px', backgroundColor: '#FFFFFF'});
  2748. modifyMyElement (vkPlayerWindow, 'div', '', false, true);
  2749. styleMyElement (vkPlayerWindow, {overflow: 'visible', height: '100%'});
  2750. appendMyElement (vkPlayerWindow, myPlayerWindow);
  2751. blockObject = vkPlayerWindow;
  2752.  
  2753. /* Resize Event */
  2754. page.win.addEventListener('resize', vkUpdateSizes, false);
  2755.  
  2756. /* Get Videos */
  2757. if (vkVideosContent) {
  2758. var vkVideoList = {};
  2759. var vkVideo = vkVideosContent.match(/"video_url":"(.*?)"/);
  2760. vkVideo = (vkVideo) ? vkVideo[1] : null;
  2761. var vkVideoThumb = vkVideosContent.match(/"image_url":"(.*?)"/);
  2762. vkVideoThumb = (vkVideoThumb) ? vkVideoThumb[1] : null;
  2763.  
  2764. /* Create Player */
  2765. if (vkVideo) {
  2766. var vkDefaultVideo = 'Low Definition MP4';
  2767. vkVideoList[vkDefaultVideo] = vkVideo
  2768. player = {
  2769. 'playerSocket': vkPlayerWindow,
  2770. 'playerWindow': myPlayerWindow,
  2771. 'videoList': vkVideoList,
  2772. 'videoPlay': vkDefaultVideo,
  2773. 'videoDuration': vkVideoDuration,
  2774. 'videoThumb': vkVideoThumb,
  2775. 'playerWidth': vkPlayerWidth,
  2776. 'playerHeight': vkPlayerHeight,
  2777. 'playerWideWidth': vkPlayerWideWidth,
  2778. 'playerWideHeight': vkPlayerWideHeight,
  2779. 'sidebarWindow': vkSidebarWindow,
  2780. 'sidebarMarginNormal': 0,
  2781. 'sidebarMarginWide': vkSidebarMarginWide
  2782. };
  2783. feature['definition'] = false;
  2784. feature['container'] = false;
  2785. option['definition'] = 'LD';
  2786. option['definitions'] = ['Low Definition'];
  2787. option['containers'] = ['MP4'];
  2788. createMyPlayer (player);
  2789. vkUpdateSizes ();
  2790.  
  2791. /* Fix panel */
  2792. //styleMyElement(player['playerContent'], {marginTop: '5px'});
  2793. styleMyElement(player['playerPanel'], {height: '22px', width: player['playerWidth'] + 'px'});
  2794. }
  2795. else {
  2796. showMyMessage ('!videos');
  2797. }
  2798. }
  2799. else {
  2800. showMyMessage ('!content');
  2801. }
  2802. }
  2803.  
  2804. }
  2805.  
  2806. // =====IMDB===== //
  2807. /* Redirect To imdb.com */
  2808. else if (page.url.indexOf('imdb.org') !== -1) window.location.href = page.win.location.href.replace(/imdb\.org/, 'imdb.com');
  2809. else if (page.url.indexOf('imdb.com/video') != -1) {
  2810.  
  2811. function imdb_run(imdb_PlayerId) {
  2812. /* Get Player Window */
  2813. var imdbPlayerWindow = getMyElement ('', 'div', 'id', 'player-article', -1, false);
  2814. /* if (imdbPlayerWindow) {
  2815. var imdbPlayerWidth = 670;
  2816. var imdbPlayerHeight = 398;
  2817. } else { */
  2818. imdbPlayerWindow = getMyElement ('', 'div', 'class', 'video-player vp-full', 0, false);
  2819. var imdbPlayerWidth = imdbPlayerWindow.clientWidth;
  2820. var imdbPlayerHeight = imdbPlayerWindow.clientHeight;
  2821. if (imdbPlayerHeight < 340) imdbPlayerHeight = 340;
  2822. // }
  2823. if (!imdbPlayerWindow) {
  2824. showMyMessage ('!player');
  2825. }
  2826. else {
  2827. imdbVideoID = getMyContent (page.url, '"viconst":"(.*?)"', false);
  2828. if (!imdbVideoID) {
  2829. imdbVideoID = page.url.match(/vi\d{5,}/);
  2830. if (imdbVideoID) imdbVideoID = imdbVideoID[0]; else imdbVideoID = getMyContent (page.url, '"viconst":"(.*?)"', true);
  2831. }
  2832. /* My Player Window */
  2833. var myPlayerWindow = createMyElement ('div', '', '', '', '');
  2834. var imdbPlayerElement = getMyElement ('', 'div', 'id', 'imdb-video', -1, false);
  2835. blockObject = imdbPlayerElement;
  2836. blockInterval = 20;
  2837.  
  2838. styleMyElement (myPlayerWindow, {position: 'relative', width: imdbPlayerWidth + 'px', height: imdbPlayerHeight + 'px', backgroundColor: '#F4F4F4'});
  2839. for (var i=0; i<imdbPlayerWindow.children.length; i++) {
  2840. if (imdbPlayerWindow.children[i].tagName == 'DIV') styleMyElement (imdbPlayerWindow.children[i], {display: 'none'});
  2841. }
  2842. appendMyElement (imdbPlayerWindow, myPlayerWindow);
  2843.  
  2844. /* Get Videos Content */
  2845. var imdbVideoList = {};
  2846. var imdbVideoFormats = {'1': 'Full High Definition MP4', '2': 'Standard Definition MP4', '3': 'High Definition MP4'};
  2847. var imdbVideoThumb, imdbDefaultVideo, imdbURL, imdbVideo, myVideoCode;
  2848. var imdbVideoFound = false;
  2849. var imdbVideoRTMP = false;
  2850. for (var imdbVideoCode in imdbVideoFormats) {
  2851. imdbURL = page.win.location.protocol + '//' + page.win.location.hostname + '/video/imdb/' + imdbVideoID + '/player?uff=' + imdbVideoCode;
  2852. imdbVideo = getMyContent (imdbURL, 'so.addVariable\\("file",\\s+"(.*?)"\\);', true);
  2853. if (!imdbVideoThumb) imdbVideoThumb = getMyContent (imdbURL, 'so.addVariable\\("image",\\s+"(.*?)"\\);', true);
  2854. /*
  2855. imdbURL = page.win.location.protocol + '//' + page.win.location.hostname + '/video/imdb/' + imdbVideoID + '/imdb/single?vPage=1&format=' + imdbVideoCode;
  2856. imdbVideo = getMyContent (imdbURL, '"videoUrl":"(.*?)"', false);
  2857. if (!imdbVideoThumb) imdbVideoThumb = getMyContent (imdbURL, '"slate":"(.*?)"', false);
  2858. */
  2859. if (imdbVideo) {
  2860. if (imdbVideo.indexOf('rtmp') != -1) {
  2861. if (!imdbVideoRTMP) imdbVideoRTMP = true;
  2862. } else {
  2863. if (!imdbVideoFound) imdbVideoFound = true;
  2864. myVideoCode = imdbVideoFormats[imdbVideoCode];
  2865. imdbVideoList[myVideoCode] = imdbVideo;
  2866. if (!imdbDefaultVideo) imdbDefaultVideo = myVideoCode;
  2867. }
  2868. }
  2869. }
  2870.  
  2871. if (imdbVideoFound) {
  2872. /* Get Watch Sidebar */
  2873. var imdbSidebarWindow = getMyElement ('', 'div', 'id', 'sidebar', -1, false);
  2874. if (imdbSidebarWindow) styleMyElement (imdbSidebarWindow, {marginTop: '-400px'});
  2875.  
  2876. /* Create Player */
  2877. var player = {
  2878. 'playerSocket': imdbPlayerWindow,
  2879. 'playerWindow': myPlayerWindow,
  2880. 'videoList': imdbVideoList,
  2881. 'videoPlay': imdbDefaultVideo,
  2882. 'videoThumb': imdbVideoThumb,
  2883. 'playerWidth': imdbPlayerWidth,
  2884. 'playerHeight': imdbPlayerHeight,
  2885. 'playerWideWidth': 1010,
  2886. 'playerWideHeight': 592,
  2887. 'sidebarWindow': imdbSidebarWindow,
  2888. 'sidebarMarginNormal': -400,
  2889. 'sidebarMarginWide': 0
  2890. };
  2891. feature['container'] = false;
  2892. option['definitions'] = ['High Definition', 'Standard Definition', 'Low Definition'];
  2893. option['containers'] = ['MP4'];
  2894. createMyPlayer (player);
  2895. }
  2896. else {
  2897. if (imdbVideoRTMP) showMyMessage ('!support');
  2898. else showMyMessage ('!videos');
  2899. }
  2900. }
  2901. }
  2902.  
  2903. function onNodeInserted(e) {
  2904. if (e && e.target && (typeof e.target.id !== 'undefined') && e.target.id == 'imdb-video-player') {
  2905. setTimeout(function() { imdb_run(); }, 0);
  2906. }
  2907. }
  2908.  
  2909. if (page.url.indexOf('video/playlist') == -1) imdb_run();
  2910. else {
  2911. var content = getMyElement ('', 'body', '', '', -1, false);
  2912. if (content) {
  2913. var mo=window.MutationObserver||window.MozMutationObserver||window.WebKitMutationObserver;
  2914. if(typeof mo!=='undefined') {
  2915. var observer=new mo(function(mutations) {
  2916. mutations.forEach(function(mutation) {
  2917. if(mutation.addedNodes!==null && mutation.addedNodes.length > 0) {
  2918. for (var i=0; i<mutation.addedNodes.length; i++) {
  2919. if ((typeof mutation.addedNodes[i].id !== 'undefined') && (mutation.addedNodes[i].id == 'imdb-video-player')) {
  2920. imdb_run(mutation.addedNodes);
  2921. break;
  2922. }
  2923. }
  2924. }
  2925. });
  2926. });
  2927. observer.observe(content, {childList: true, subtree: true, characterData:true});
  2928. } else { // MutationObserver fallback for old browsers
  2929. content.parentNode.addEventListener('DOMNodeInserted', onNodeInserted, true);
  2930. }
  2931. }
  2932. }
  2933.  
  2934. }
  2935.  
  2936. // =====Facebook===== //
  2937. else if (page.url.match('facebook.com/(video.php|.*/videos/)')) {
  2938.  
  2939. function Facebook() {
  2940.  
  2941. /* Get Videos Content */
  2942. var fbVideosContent = getMyContent(page.url, '\\\\"params\\\\",\\\\"(.*?)\\\\"', false);
  2943. var fbPattern = /\\u([\d\w]{4})/gi;
  2944. if (fbVideosContent) {
  2945. fbVideosContent = fbVideosContent.replace(fbPattern, function (match, group) {
  2946. return String.fromCharCode(parseInt(group, 16));
  2947. });
  2948. fbVideosContent = unescape(fbVideosContent).replace(/\\/g, '');
  2949. }
  2950.  
  2951. /* Get Video Thumbnail */
  2952. var fbVideoThumb = getMyContent(page.url, 'background-image:\\s+url\\((.*?)\\);', false);
  2953. if (fbVideoThumb) fbVideoThumb = fbVideoThumb.replace(/&amp;/g, '&');
  2954. else fbVideoThumb = 'https://www.facebook.com/images/fb_icon_325x325.png';
  2955.  
  2956. /* Kill Theater */
  2957. var fbTheaterWaitCount = 20;
  2958. var fbPhotoTheater;
  2959. function fbTheaterWaitFunc() {
  2960. fbPhotoTheater = getMyElement ('', 'div', 'class', 'uiLayer', 0, false);
  2961. if (fbPhotoTheater) {
  2962. styleMyElement(fbPhotoTheater, {display: 'none'});
  2963. //styleMyElement (page.body.firstChild, {position: 'relative'});
  2964. page.body.firstChild.setAttribute('style', 'position:relative !important');
  2965. var fbTheaterVideo = getMyElement (fbPhotoTheater, 'video', 'tag', '', -1, false)[0];
  2966. if (fbTheaterVideo) {
  2967. fbTheaterVideo.pause();
  2968. page.win.clearInterval(fbTheaterWaitInterval);
  2969. }
  2970. }
  2971. fbTheaterWaitCount--;
  2972. if (fbTheaterWaitCount == 0) {
  2973. page.win.clearInterval(fbTheaterWaitInterval);
  2974. }
  2975. }
  2976. var fbTheaterWaitInterval = page.win.setInterval(fbTheaterWaitFunc, 500);
  2977.  
  2978. /* Fix Size */
  2979. var fbContentWrapperId = getMyContent(page.url, '\\\\"object_element_id\\\\":\\\\"(.*?)\\\\"', false);
  2980. if (fbContentWrapperId) {
  2981. var fbContentWrapper= getMyElement ('', 'div', 'id', fbContentWrapperId, -1, false);
  2982. if (fbContentWrapper) styleMyElement(fbContentWrapper, {minWidth: '660px', marginLeft: '-160px'});
  2983. }
  2984.  
  2985. /* My Player Window */
  2986. myPlayerWindow = createMyElement ('div', '', '', '', '');
  2987. styleMyElement (myPlayerWindow, {position: 'relative', width: '640px', height: '382px', backgroundColor: '#F4F4F4'});
  2988. modifyMyElement (fbPlayerWindow, 'div', '', false, true);
  2989. appendMyElement (fbPlayerWindow, myPlayerWindow);
  2990. blockObject = fbPlayerWindow;
  2991.  
  2992. /* Get Videos */
  2993. if (fbVideosContent) {
  2994. var fbVideoList = {};
  2995. var fbVideoFormats = {'sd_src': 'Low Definition MP4', 'hd_src': 'High Definition MP4'};
  2996. var fbVideoFound = false;
  2997. var fbVideoPattern, fbVideo, myVideoCode, fbDefaultVideo;
  2998. for (var fbVideoCode in fbVideoFormats) {
  2999. fbVideoPattern = '"' + fbVideoCode + '":"(.*?)"';
  3000. fbVideo = fbVideosContent.match(fbVideoPattern);
  3001. fbVideo = (fbVideo) ? fbVideo[1] : null;
  3002. if (fbVideo) {
  3003. fbVideo = cleanMyContent(fbVideo, false);
  3004. if (!fbVideoFound) fbVideoFound = true;
  3005. myVideoCode = fbVideoFormats[fbVideoCode];
  3006. if (fbVideo.indexOf('.flv') != -1) myVideoCode = myVideoCode.replace('MP4', 'FLV');
  3007. fbVideoList[myVideoCode] = fbVideo;
  3008. if (!fbDefaultVideo) fbDefaultVideo = myVideoCode;
  3009. }
  3010. }
  3011.  
  3012. if (fbVideoFound) {
  3013. /* Create Player */
  3014. player = {
  3015. 'playerSocket': fbPlayerWindow,
  3016. 'playerWindow': myPlayerWindow,
  3017. 'videoList': fbVideoList,
  3018. 'videoPlay': fbDefaultVideo,
  3019. 'videoThumb': fbVideoThumb,
  3020. 'playerWidth': 640,
  3021. 'playerHeight': 382
  3022. };
  3023. feature['widesize'] = false;
  3024. option['definitions'] = ['High Definition', 'Low Definition'];
  3025. option['containers'] = ['MP4', 'FLV', 'Any'];
  3026. createMyPlayer (player);
  3027. }
  3028. else {
  3029. showMyMessage ('!videos');
  3030. }
  3031. }
  3032. else {
  3033. showMyMessage ('!content');
  3034. }
  3035.  
  3036. }
  3037.  
  3038. var myPlayerWindow;
  3039. var fbPlayerWindow = getMyElement ('', 'div', 'class', 'videoStage', 0, false);
  3040. if (fbPlayerWindow) {
  3041. Facebook();
  3042. }
  3043. else {
  3044. var fbPlayerWaitCount = 20;
  3045. function fbPlayerWaitFunc() {
  3046. fbPlayerWindow = getMyElement ('', 'div', 'class', 'mtm', 0, false);
  3047. if (fbPlayerWindow) {
  3048. page.win.clearInterval(fbPlayerWaitInterval);
  3049. Facebook();
  3050. }
  3051. fbPlayerWaitCount--;
  3052. if (fbPlayerWaitCount == 0) {
  3053. page.win.clearInterval(fbPlayerWaitInterval);
  3054. showMyMessage ('!player');
  3055. }
  3056. }
  3057. var fbPlayerWaitInterval = page.win.setInterval(fbPlayerWaitFunc, 500);
  3058. }
  3059.  
  3060. }
  3061.  
  3062. // =====Owncloud===== //
  3063. else if (page.url.indexOf('/owncloud/apps') != -1 || page.url.indexOf('/nextcloud/apps') != -1) {
  3064. /* Get Player Window */
  3065.  
  3066. function ocRun (isMutation) {
  3067. var ocPlayerWindow = getMyElement ('', 'div', 'id', 'videoplayer_overlay', -1, false);
  3068. if (ocPlayerWindow && ocPlayerWindow.children[0]) {
  3069. ocPlayerWindow = ocPlayerWindow.children[0];
  3070.  
  3071. /* Get Videos Content */
  3072. var ocVideoFound = false;
  3073. var ocVideoList = {};
  3074. var ocVideoSrc = getMyContent(page.url, '<video.*?<source type="video.*?src="(.*?)".*</video>', false);
  3075. /* Get Videos */
  3076. if (ocVideoSrc) {
  3077. ocVideoSrc = unescape(ocVideoSrc);
  3078. ocVideoSrc = escape(ocVideoSrc.replace( '/index.php/apps/files/ajax/download.php?dir=/', '/remote.php/webdav/').replace('&amp;files=','/'));
  3079. // only for trhome!
  3080. // if (page.win.location.hostname.indexOf('trhome.my-router.de') != -1) ocVideoSrc = ocVideoSrc.replace('/owncloud/remote.php','');
  3081. ocVideoFound = true;
  3082. }
  3083. /* Get Video Thumbnail */
  3084. /* implement it via ImDB */
  3085.  
  3086. /* My Player Window */
  3087. var myPlayerWindow = createMyElement ('div', '', '', '', '');
  3088. var ocPlayerWidth = ocPlayerWindow.children[0].offsetWidth;
  3089. var ocPlayerHeight = ocPlayerWindow.children[0].offsetHeight;
  3090. styleMyElement (myPlayerWindow, {position: 'relative', width: ocPlayerWidth + 'px', height: ocPlayerHeight+ 'px', backgroundColor: '#F4F4F4', margin: '0px auto'});
  3091. modifyMyElement (ocPlayerWindow, 'div', '', true);
  3092. styleMyElement (ocPlayerWindow, {position: 'relative!important', top: '50px', left: '50px', right: '50px',bottom: '50px', transform: 'initial', margin: '0px auto'});
  3093. appendMyElement (ocPlayerWindow, myPlayerWindow);
  3094.  
  3095. if (ocVideoFound) {
  3096. if (ocVideoSrc.indexOf(page.win.location.hostname) != -1) ocVideoList['Standard Definition MP4'] = ocVideoSrc.replace(page.win.location.protocol.slice(0,page.win.location.protocol.length-1)+'%3A//',page.win.location.protocol.slice(0,page.win.location.protocol.length-1)+'://');
  3097. else ocVideoList['Standard Definition MP4'] = page.win.location.protocol + '//' + page.win.location.hostname + ocVideoSrc ;
  3098. /* Create Player */
  3099. var ocuser = getMyOption('user');
  3100. var ocpasswd = getMyOption('passwd');
  3101. var ysDefaultVideo = 'Standard Definition MP4';
  3102. var player = {
  3103. 'panelHeight': 22,
  3104. 'user': ocuser,
  3105. 'passwd': ocpasswd,
  3106. 'playerSocket': ocPlayerWindow,
  3107. 'playerWindow': myPlayerWindow,
  3108. 'videoList': ocVideoList,
  3109. 'videoPlay': ysDefaultVideo,
  3110. // 'videoThumb': ocVideoThumb,
  3111. 'playerWidth': ocPlayerWidth,
  3112. 'playerHeight': ocPlayerHeight
  3113. };
  3114. feature['widesize'] = false;
  3115. feature['PWdialog'] = true;
  3116. option['definitions'] = ['Standard Definition'];
  3117. option['containers'] = ['Any'];
  3118. HeadWindow = getMyElement ('', 'div', 'id', 'header', -1, false);
  3119. createMyPlayer (player);
  3120. if (!ocuser) passwdDialog (player);
  3121. }
  3122. else {
  3123. showMyMessage ('!videos');
  3124. }
  3125. }
  3126. }
  3127.  
  3128. function onNodeInserted(e) {
  3129. if (e && e.target && e.target.id=='videoplayer_container') {
  3130. setTimeout(function() { ocRun(); }, 0);
  3131. }
  3132. }
  3133.  
  3134. var content=document.getElementById('body-user');
  3135. window.addEventListener("hashchange", onNodeInserted(), false)
  3136. var mo=window.MutationObserver||window.MozMutationObserver||window.WebKitMutationObserver;
  3137. if (content && typeof mo!=='undefined') {
  3138. var observer=new mo(function(mutations) {
  3139. mutations.forEach(function(mutation) {
  3140. if(mutation.addedNodes!==null && mutation.addedNodes.length > 0) {
  3141. for (var i=0; i<mutation.addedNodes.length; i++) {
  3142. if (mutation.addedNodes[i].id == 'videoplayer_overlay') {
  3143. ocRun(mutation.addedNodes);
  3144. break;
  3145. }
  3146. }
  3147. }
  3148. });
  3149. });
  3150. observer.observe(content, {childList: true, subtree: true});
  3151. }
  3152. else {
  3153. window.addEventListener('DOMNodeInserted', onNodeInserted(e), false);
  3154. }
  3155.  
  3156. }
  3157.  
  3158. })();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址