Wikitube - YouTube on 維基百科 & 百度百科

Adds relevant YouTube videos to 維基百科 & 百度百科

目前為 2020-06-26 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name Wikitube - YouTube on Wikipedia & 百度百科
  3. // @name:zh-CN Wikitube - YouTube on 维基百科 & 百度百科
  4. // @name:zh-TW Wikitube - YouTube on 維基百科 & 百度百科
  5. // @namespace WYOWW
  6. // @version 3.3.8
  7. // @description Adds relevant YouTube videos to Wikipedia & 百度百科
  8. // @description:zh-cn Adds relevant YouTube videos to 维基百科 & 百度百科
  9. // @description:zh-TW Adds relevant YouTube videos to 維基百科 & 百度百科
  10. // @include http*://*.wikipedia.org/wiki*
  11. // @include http*://baike.baidu.com/item/*
  12. // @require http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js
  13. // @author Mark Dunne | http://markdunne.github.io/ | https://chrome.google.com/webstore/detail/wikitube/aneddidibfifdpbeppmpoackniodpekj
  14. // @developer vinc, drhouse
  15. // @icon https://en.wikipedia.org/static/favicon/wikipedia.ico
  16. // ==/UserScript==
  17.  
  18. $(document).ready(function () {
  19.  
  20. const YOUTUBE_DATA_API_CREDENTIAL_ = 'AIzaSyC1ucHysupgOH1JQmPaGqfFGoO1QCCOhQA';
  21. const YOUTUBE_DATA_API_CREDENTIAL_1 = 'AIzaSyCRziwj9Gem35VEPYva9oHBvoLXKPpYI-o';
  22.  
  23. // pages of wikipedia which should disable Wikitube
  24. var banned_paths = [
  25. '/wiki/Main_Page',
  26. ];
  27. var banned_paths_prefix = [
  28. '/wiki/Help:',
  29. '/wiki/Wikipedia:',
  30. '/wiki/User:',
  31. '/wiki/Special:'
  32. ];
  33.  
  34. function addGlobalStyle(css) {
  35. var head, style;
  36. head = document.getElementsByTagName('head')[0];
  37. if (!head) { return; }
  38. style = document.createElement('style');
  39. style.type = 'text/css';
  40. style.innerHTML = css;
  41. head.appendChild(style);
  42. }
  43.  
  44. addGlobalStyle('#wikitube_container { padding-bottom: 30px; overflow-y:hidden; white-space: nowrap; }');
  45. addGlobalStyle('#wikitube_container::-webkit-scrollbar { width: 0px; background: transparent; }');
  46. addGlobalStyle('#wikitube_container div { width: auto; height: 200px; margin-right: 5px; display: inline-block; box-shadow: 0 0 5px #888; }');
  47. addGlobalStyle('#wikitube_container .plusBtn { width: 100px; text-align: center; border-radius: 5px; background-color: rgb(192, 62, 62); background-position: center; background-repeat: no-repeat; cursor: pointer;}');
  48. addGlobalStyle('#wikitube_container .plusBtn:hover { background-color: rgb(192, 92, 92); }');
  49.  
  50. var allow_path = function(path){
  51. console.log(path);
  52. for (var i = 0; i < banned_paths_prefix.length; i++){
  53. if(path.startsWith(banned_paths_prefix[i])){
  54. return false;
  55. }
  56. }
  57. for (var i = 0; i < banned_paths.length; i++) {
  58. if(path == banned_paths[i]){
  59. return false;
  60. }
  61. }
  62. return true;
  63. }
  64.  
  65. var title_text;
  66. var num_videos_to_load;
  67. var num_videos_loaded = 0;
  68. var more_videos_button = $('<div class="plusBtn" title="Load more videos!"></div>');
  69. var container = $('<div id="wikitube_container"></div>');
  70.  
  71. var first_load = function(){
  72. if( $('#mw-content-text').length ){ // wikipedia
  73. container.insertBefore('#mw-content-text');
  74. }else if( $('.main-content').length ){ // 百度百科
  75. container.insertBefore('.main-content');
  76. }
  77. container.append(more_videos_button);
  78.  
  79. var plusImgURL = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtv\
  80. UhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89+bN/rXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz/SMBAPh+PDwrIsAHvgABeNMLCADATZvAMByH/w/qQplcA\
  81. YCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf+bTAICd+Jl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ\
  82. 5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA/g88wAAKCRFRHgg/P9eM4Ors7ONo62Dl8t6r8G/yJiYuP+5c+rcEAAAOF0ftH+LC+zGoA7BoBt/qIl7gRoXgugdfeLZrIPQLUAoOnaV/Nw+H48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl/AV/1s+X\
  83. 48/Pf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H/LcL'+'/'+'/wd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s+wM+3zUAsGo+AXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93/+8//UegJQCAZkmScQAAXkQkLlTKsz/HCAAA\
  84. RKCBKrBBG/TBGCzABhzBBdzBC/xgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD/phCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyU\
  85. T3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8+Q8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8+xdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR+cQYYjIxh1hILCPWEo8TLxB7iEPENyQ\
  86. SiUMyJ7mQAkmxpFTSEtJG0m5SI+ksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG+Qh8lsKnWJAcaT4U+IoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr+h0uhHdlR5Ol9BX0svpR+iX6AP0dwwNhh\
  87. WDx4hnKBmbGAcYZxl3GK+YTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI+pXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q/pH5Z/YkGWcNMw09DpFGgsV/jvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY/R\
  88. 27iz2qqaE5QzNKM1ezUvOUZj8H45hx+Jx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4/OBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up+6Ynr5egJ5Mb6feeb3n+hx9L/1U/W36p/VHDFgGswwkBts\
  89. Mzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm+eb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2q\
  90. bcZsOXYBtuutm22fWFnYhdnt8Wuw+6TvZN9un2N/T0HDYfZDqsdWh1+c7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc+Lpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26/uNu5p7ofcn8w0nymeWTNz0MPIQ+BR5dE/C5+V\
  91. MGvfrH5PQ0+BZ7XnIy9jL5FXrdewt6V3qvdh7xc+9j5yn+M+4zw33jLeWV/MN8C3yLfLT8Nvnl+F30N/I/9k/3r/0QCngCUBZwOJgUGBWwL7+Hp8Ib+OPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga\
  92. 0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo+qi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt/87fOH4p3iC+N7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi/RNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMD\
  93. UzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z+pn5mZ2y6xlhbL+xW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a/zYnKOZarnivN7cyzytuQN5zvn//tEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQF\
  94. r6wtVCuWFfevc1+1dT1gvWd+1YfqGnRs+FYmKrhTbF5cVf9go3HjlG4dvyr+Z3JS0qavEuWTPZtJm6ebeLZ5bDpaql+aXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO/PLi8ZafJzs07P1SkVPRU+lQ27tLdtWHX+G7R7ht7vPY07NXbW7z3/T7JvttVAVVN1WbVZftJ+7\
  95. P3P66Jqun4lvttXa1ObXHtxwPSA/0HIw6217nU1R3SPVRSj9Yr60cOxx++/p3vdy0NNg1VjZzG4iNwRHnk6fcJ3/ceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w+0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb++6EH\
  96. Th0kX/i+c7vDvOXPK4dPKy2+UTV7hXmq86X23qdOo8/pPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb/1tWeOT3dvfN6b/fF9/XfFt1+cif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v+3Njv3H9qwHeg89HcR/cGhYPP/pH1jw9DBY+Zj8uGDYbrnjg+OTniP3L96fy\
  97. nQ89kzyaeF/6i/suuFxYvfvjV69fO0ZjRoZfyl5O/bXyl/erA6xmv28bCxh6+yXgzMV70VvvtwXfcdx3vo98PT+R8IH8o/2j5sfVT0Kf7kxmTk/8EA5jz/GMzLdsAAAAgY0hSTQAAeiUAAICDAAD5/wAAgOkAAHUwAADqYAAAOpgAABdvkl/FRgAAAMZQTFRFERER////ERERE\
  98. RERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERERER\
  99. ERERERERERERERERERERERERERERERERERERERERERERlvLzngAAAEF0Uk5TAAABAgMEBQYHCAkKCwwNDg8QEhUXGBkaHR4gISMkJSYpKy4xMjM0Nzg7PUFGR0hNZWZnr7fHyNrb5ufo8vP19v4deCuTAAACGklEQVRYw+2XWXOiQBSFnV6jgmy2gqC4oSgGY3RMJjEL//9PxQAd\
  100. DTFTtD0PTlXO65WvKLvv4ZzKL0lVLgJQOS0AIMKEEIwgAKd/8jcAgJhWFU03dE2pUQyBIAAgWtetltNxO07L0usUASEAQFcNy/aHk2k4nQx922pcnSJ8C9g/r7Hu6GZ995Q83a1Xoy7TThG+BxC16cfbhOt37DdVIgCAVdNdPCQH/Vm4ZhWWByCFDTbJsTYDpqDyAKzZwcsnwEtga\
  101. 7g8gBhumHxW6BqkPICa3qwAmHkmFQH05gXAvPcDuHxAZj80l8r6UQEQ9ZmaTw8edQAARPb2Y5i5mBfEBUAceCyfGppSJelyfwD2+6+azHa9XqZ+EC0LgGUU9LOh59rMVFN74IB3/2i6gyCczTNF8fILYBlH2XAWBgO3mRoMB0DaYP5i85yU1PNm4bMGhRwAcN3qXj8mAnq87lp1DDi\
  102. A6s5omwhpO7J1ygGwZvmrRFAr36rBHICU1nAtClgPWwrKAVhzJveigPuJo+EcQPTOdCcK2E07OuGAvQO+igJe303yX72B9H+AlPY5p9D+OIWz7sHt0T047yY6h5uY7kIssQt8G0ufxK6wjdwPxmX9YFz0A2lHkvdEeVf++bRdJEAyZEnHvK9BczcWCprSUTcN28cG8SAYtotxfysa9/\
  103. PCsTq7cEhXHl662meXrqz21SRqn1Dx/M/L9xutmnjEud3T6wAAAABJRU5ErkJggg==';
  104.  
  105. more_videos_button.css('background-image', 'url(' + plusImgURL + ')');
  106.  
  107. more_videos_button.click(function(){
  108. load_new_videos(false);
  109. });
  110.  
  111. $('iframe').ready(function(){
  112. vinc_set_horiz_scroll();
  113. });
  114. }
  115.  
  116. var load_new_videos = function(is_first_load){
  117. var url = 'https://www.googleapis.com/youtube/v3/search?part=snippet&q='+title_text+'&key=' + YOUTUBE_DATA_API_CREDENTIAL_1 + '&maxResults='+(num_videos_loaded+num_videos_to_load);
  118. $.getJSON(url, function(response){
  119. if(response['items'].length > 0){
  120. if (is_first_load) {
  121. first_load();
  122. }
  123. var new_videos = videos = response['items'];
  124. new_videos = new_videos.slice(num_videos_loaded);
  125. num_videos_loaded += num_videos_to_load;
  126. add_videos_to_page(new_videos);
  127. }
  128. });
  129. }
  130.  
  131. var add_videos_to_page = function(new_videos){
  132. for (var i = 0; i < new_videos.length; i++) {
  133. video = new_videos[i];
  134. var videoHtml = '<div class="vinc_yt"><iframe width="350" height="200" frameborder="0" allowfullscreen src="//www.youtube.com/embed/'+video['id']['videoId']+'"></iframe></div>';
  135. more_videos_button.before(videoHtml);
  136. };
  137. }
  138.  
  139. var test_func = function(){
  140. url = 'https://www.googleapis.com/youtube/v3/search?part=snippet&q=memes&key=' + YOUTUBE_DATA_API_CREDENTIAL_1;
  141. $.getJSON(url, function(response){
  142. console.log(response);
  143. })
  144. }
  145.  
  146. var vinc_set_horiz_scroll = function(){
  147. $('#wikitube_container').on('mousewheel DOMMouseScroll', function(e){
  148. var delt = null;
  149.  
  150. if (e.type == 'mousewheel') {
  151. delt = (e.originalEvent.wheelDelta * -1);
  152. }
  153. else if (e.type == 'DOMMouseScroll') {
  154. delt = 40 * e.originalEvent.detail;
  155. }
  156.  
  157. if (delt) {
  158. e.preventDefault();
  159. $(this).scrollLeft(delt + $(this).scrollLeft());
  160. }
  161. });
  162. }
  163.  
  164. // main code
  165. if(allow_path(window.location.pathname)){
  166. if( $('#mw-content-text').length ){ // wikipedia
  167.  
  168. // title_text = document.getElementById('firstHeading').innerText;
  169. title_text = $("#firstHeading")[0].textContent;
  170. num_videos_to_load = Math.floor($('#bodyContent').width() / 350) + 1; //video width = 350px
  171.  
  172. }else if( $('.main-content').length ){ // 百度百科
  173.  
  174. title_text = $(".lemmaWgt-lemmaTitle-title h1")[0].textContent;
  175. num_videos_to_load = Math.floor($('.body-wrapper .content-wrapper .content').width() / 350) + 1; //video width = 350px
  176.  
  177. }
  178. load_new_videos(true);
  179. }
  180.  
  181. });

QingJ © 2025

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