bt_search_for_bgm

add search icons in bangumi.tv for search anime

当前为 2015-09-30 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name        bt_search_for_bgm
// @namespace   http://bangumi.tv/user/a_little
// @description add search icons in bangumi.tv for search anime 
// @include     /^https?://(bangumi|bgm|chii)\.(tv|in)/(subject|index|anime|game|book|subject_search)/.*$/
// @include     /^https?://(bangumi|bgm|chii).(tv|in)/$/
// @version     0.13
// @grant       GM_addStyle
// ==/UserScript==

if (!localStorage.getItem('searchEngines') || typeof JSON.parse(localStorage.getItem('searchEngines')) !== 'object') {
  localStorage.setItem('searchEngines', JSON.stringify(['dmhy', 'google', 'btdigg']));
}
var searchEngines = JSON.parse(localStorage.getItem('searchEngines'));
// Here, you can choose search engines that you want.
var searchEngineLists = [
  "dmhy",
  "camoe",
  "popgo",
  "google",
  "btdigg",
  "nyaa",
  "tokyotosho",
  "breadsearch",
];

// the engines in first list will search Chinese name by default.
// The engines in second list may need a ladder to acess them. Search Japanese name by default.
var allSearchEngineLists = [
  ["dmhy", "camoe", "popgo"],
  ["google", "btdigg", "nyaa", "tokyotosho", "breadsearch"]
];

// You can add new search engines in here.
// Data format and order like this: name : ["title", "icon", "searchapi"].
// In "searchapi", query string should indead by {searchTerms}.
// And you should add new engines in allSearchEngineLists, otherwise, it doesn't work.
var searchAPIs = {
  dmhy : [
    "花园搜索",
    "",
    "http://share.dmhy.org/topics/list?keyword={searchTerms}"
  ],
  camoe : [
    "华盟搜索",
    "",
    "https://camoe.org/search.php?keyword={searchTerms}"
  ],
  popgo : [
    "漫游搜索",
    "",
    "http://share.popgo.org/search.php?title={searchTerms}"
  ],
  google : [
    "Download Search",
    "",
    "https://www.google.com/cse?q=&newwindow=1&cx=006100883259189159113%3Atwgohm0sz8q#gsc.tab=0&gsc.sort=&gsc.ref=more%3Ap2p&gsc.q={searchTerms}"
  ],
  btdigg : [
    "btdigg",
    "",
    "http://btdigg.org/search?info_hash=&q={searchTerms}"
  ],
  nyaa : [
    "nyaaSearch",
    "",
    "http://sukebei.nyaa.eu/?page=search&cats=7_25&filter=0&term={searchTerms}"
  ],
  tokyotosho : [
    "tokyotosho",
    "",
    "http://www.tokyotosho.info/search.php?terms={searchTerms}&type=0&size_min=&size_max=&username="
  ],
  breadsearch : [
    "breadsearch",
    "",
    "http://www.breadsearch.com/search/{searchTerms}"
  ],

};

// Create anchor for search with a icon.
// Codes come from Bangumi Music+(http://bgm.tv/group/topic/10395) and make some modifications.
function createLink(link) {
  //    console.log("start create link in createLink function");
  var searchIcon = document.createElement("a");
  searchIcon.href = link;
  searchIcon.target = "_blank";
  searchIcon.className = "searchicon";
  var searchIconImg = document.createElement("img");
  searchIconImg.style.cssText = "display:inline-block;border:none;height:12px;width:14px;margin-left:2px";
  searchIcon.appendChild(searchIconImg);
  // add title and icon
  domain = /[\/|\.|www]*(\w+)\.[org|com|se|info]/.exec(link)[1];
  searchIcon.title = searchAPIs[domain][0];
  searchIconImg.src = searchAPIs[domain][1];
  //    console.log(domain, ":createLink success");
  return searchIcon;
}

function getChineseName(title) {
  if (window.location.href.match(/subject_search|index/))
    return title.getElementsByClassName("l")[0].textContent;
  if (title.getElementsByTagName("a")[0].title)
    return title.children[0].title;
  return title.children[0].textContent;
}

function getJanpaneseName(title) {
  if (window.location.href.match(/subject_search/)) {
    if (title.getElementsByClassName("grey").length)
      return title.getElementsByClassName("grey")[0].textContent;
    else
      return title.getElementsByClassName("l")[0].textContent;
  }
  if (title.tagName === "H3" && title.children[1] !== undefined) {
    return title.children[1].textContent;
  }
  else if (title.tagName === "H1")
    return title.children[0].textContent;
  return "";
}

function contains(val, arr) {
  for (var i = 0; i < arr.length; i++) {
    if (arr[i] === val)
      return true;
  }
  return false;
}

function getLink(engineName, animeName) {
  return searchAPIs[engineName][2].replace(/\{searchTerms\}/, encodeURIComponent(animeName));
}

// add search icon in subject page
function addSearchIcon1() {
  var h1 = document.getElementsByTagName("h1")[0];
  // add bt search text
  /*
     var frag = document.createDocumentFragment('frag');
     var span = document.createElement('span');
     span.id = 'bt-search';
     span.textContent = "BT搜索:";
     span.style.cssText = "width:14px !important; height:12px !important; color:rgb(0,180,30);margin-left:100px;cursor:pointer;";
     frag.appendChild(span);
     h1.appendChild(frag);
     */
  if (h1) {
    for (var i = 0, len = searchEngines.length; i < len; i++) {
      var animeName = getChineseName(h1);
      var engineName = searchEngines[i];
      if (contains(engineName, allSearchEngineLists[1]) || !animeName.length)
        animeName = getJanpaneseName(h1);

      h1.appendChild(createLink(getLink(engineName, animeName)));
    }
  }
}

// add search icon in anime or index page
function addSearchIcon2() {
  //    if (window.location.href.match(/subject_search/))
  for (var i = 0, len = document.getElementsByTagName("h3").length; i < len; i++) {
    var h3 = document.getElementsByTagName("h3")[i];
    for (var j = 0; j < searchEngines.length; j++) {
      var animeName = getJanpaneseName(h3);
      var engineName = searchEngines[j];
      if (contains(engineName, allSearchEngineLists[0]) || !animeName.length)
        animeName = getChineseName(h3);
      h3.appendChild(createLink(getLink(engineName, animeName)));
    }
  }
}


if (window.location.href.match("/subject/") && document.getElementById("navMenuNeue").children[2].children[0].className !== "focus chl")
  addSearchIcon1();
else if (window.location.href.match("/anime|index|game|book|subject_search/"))
  addSearchIcon2();

var searchSwitch = {
  init: function() {
    if (this.isHomepge()) {
      this.addStyle();
      this.insertStatus();
      this.insertSearchEngineSwitch();
    }
  },
  isHomepge: function() {
    return window.location.pathname === '/' ? true : false;
  },
  addStyle: function(css) {

    if (css) {
      GM_addStyle(css);
    } else {
      GM_addStyle([
        '.search-switches {display:none;}',
        '*:hover > .search-switches {display:block;}',
        '.search-switches a {display:inline-block;float:left;margin:5px 5px;padding:5px 5px;border-radius:4px;box-shadow:1px 1px 2px #333;}',
        '.search-switches a.engine-off {background:#ccffcc none repeat scroll 0 0;color:#333;}',
        '.search-switches a.engine-on {background:#f09199 none repeat scroll 0 0;color:#fff;}'
      ].join(''));
    }
  },
  insertStatus: function() {
    var b = document.querySelector('#columnHomeB');
    if (b) {
      var status = document.createElement('span');
      status.className = 'search-status';
      status.textContent = '已开启'+ searchEngines.length + '个搜索引擎';
      b.appendChild(status);
      var div = document.createElement('div');
      div.className = 'search-switches';
      b.appendChild(div);
    }
    b.innerHTML += '<br />';
  },
  insertSearchEngineSwitch: function() {
    var div = document.querySelector('.search-switches');
    for (var i = 0; i < searchEngineLists.length; i += 1) {
      if (searchEngines.indexOf(searchEngineLists[i]) > -1) {
        div.appendChild(this.createSwitch(searchEngineLists[i], 'engine-on'));
      } else {
        div.appendChild(this.createSwitch(searchEngineLists[i], 'engine-off'));
      }
    }
  },
  createSwitch: function(name, aclass) {
    var a = document.createElement('a');
    a.className = aclass;
    a.textContent = name;
    a.href = '#';
    a.addEventListener('click', function(e) {
      var engines = JSON.parse(localStorage.getItem('searchEngines'));
      if (e.target.className === 'engine-on') {
        e.target.className = 'engine-off';
        var index = engines.indexOf(e.target.textContent);
        if (index > -1) engines.splice(index, 1);
      } else {
        e.target.className = 'engine-on';
        engines.push(e.target.textContent);
      }
      var status = document.querySelector('.search-status');
      status.textContent = '已开启'+ document.querySelectorAll('.engine-on').length + '个搜索引擎';
      localStorage.setItem('searchEngines', JSON.stringify(engines));
      e.preventDefault();
    });
    return a;
  }
};

searchSwitch.init();