linkDoubanTrakt

在豆瓣和 trakt 之间增加跳转链接

目前为 2022-08-21 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name linkDoubanTrakt
  3. // @namespace http://tampermonkey.net/
  4. // @version 0.1
  5. // @description 在豆瓣和 trakt 之间增加跳转链接
  6. // @description:zh-CN 在豆瓣和 trakt 之间增加跳转链接
  7. // @description:en add trakt link on douban, and vice versa
  8. // @author Kjtsune
  9. // @match https://movie.douban.com/top250*
  10. // @match https://movie.douban.com/subject/*
  11. // @match https://trakt.tv/movies/*
  12. // @match https://trakt.tv/shows/*
  13. // @icon https://www.google.com/s2/favicons?sz=64&domain=douban.com
  14. // @grant GM.xmlHttpRequest
  15. // @connect api.douban.com
  16. // @connect movie.douban.com
  17. // @license MIT
  18. // ==/UserScript==
  19. "use strict";
  20.  
  21.  
  22. function getURL_GM(url) {
  23. return new Promise(resolve => GM.xmlHttpRequest({
  24. method: 'GET',
  25. url: url,
  26. onload: function (response) {
  27. if (response.status >= 200 && response.status < 400) {
  28. resolve(response.responseText);
  29. } else {
  30. console.error(`Error getting ${url}:`, response.status, response.statusText, response.responseText);
  31. resolve();
  32. }
  33. },
  34. onerror: function (response) {
  35. console.error(`Error during GM.xmlHttpRequest to ${url}:`, response.statusText);
  36. resolve();
  37. }
  38. }));
  39. }
  40.  
  41. async function getJSON_GM(url) {
  42. const data = await getURL_GM(url);
  43. if (data) {
  44. return JSON.parse(data);
  45. }
  46. }
  47.  
  48. async function getDoubanId(imdbId) {
  49. const search = await getJSON_GM(`https://movie.douban.com/j/subject_suggest?q=${imdbId}`);
  50. if (search && search.length > 0 && search[0].id) {
  51. return search[0].id
  52. }
  53. }
  54.  
  55. function addTraktLink() {
  56. if (window.location.host != 'movie.douban.com') { return };
  57. // if (window.location.host.search(/douban/) == -1) { return };
  58. let traktA = document.querySelector('#traktLink');
  59. let imdbA = document.querySelector('#info > a[href^=https\\:\\/\\/www\\.imdb');
  60. if (!traktA && imdbA) {
  61. let imdbId = imdbA.textContent
  62. let traktHtml = `<a id="traktLink" href="https://trakt.tv/search/imdb?query=${imdbId}" target="_blank"> Trakt</a>`
  63. imdbA.insertAdjacentHTML("afterend", traktHtml);
  64. }
  65. }
  66.  
  67. async function addDoubanLink() {
  68. if (window.location.host != 'trakt.tv') { return };
  69. let doubanA = document.querySelector('#doubanLink');
  70. let imdbA = document.querySelector('#external-link-imdb');
  71. if (!doubanA && imdbA) {
  72. let imdbId = imdbA.href.split('/').at(-1);
  73. let doubanId = await getDoubanId(imdbId);
  74. let douhanHtml = `<a id="doubanLink" href="https://movie.douban.com/subject/${doubanId}/" target="_blank">Douban</a>`
  75. imdbA.insertAdjacentHTML("beforebegin", douhanHtml);
  76. }
  77.  
  78. }
  79.  
  80. function douban_delete_old(item) {
  81. let year = item.querySelector('p').textContent.split('\n')[2].match(/\d+/)[0]
  82. if (Number(year) < 2000 || Number(year) > 2010) {
  83. item.remove()
  84. }
  85. }
  86.  
  87. // clean top250
  88.  
  89. // let movieList = document.querySelectorAll('ol.grid_view > li')
  90. // movieList.forEach(douban_delete_old)
  91.  
  92. addTraktLink()
  93. addDoubanLink()