linkDoubanTrakt

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

目前為 2023-09-08 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name linkDoubanTrakt
  3. // @namespace http://tampermonkey.net/
  4. // @version 0.2
  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. if (location.href.contains('seasons')) return;
  70. let doubanA = document.querySelector('#doubanLink');
  71. let imdbA = document.querySelector('#external-link-imdb');
  72. if (!doubanA && imdbA) {
  73. let imdbId = imdbA.href.split('/').at(-1);
  74. let doubanId = await getDoubanId(imdbId);
  75. let douhanHtml = `<a id="doubanLink" href="https://movie.douban.com/subject/${doubanId}/" target="_blank">Douban</a>`
  76. imdbA.insertAdjacentHTML("beforebegin", douhanHtml);
  77. }
  78.  
  79. }
  80.  
  81. function douban_delete_old(item) {
  82. let year = item.querySelector('p').textContent.split('\n')[2].match(/\d+/)[0]
  83. if (Number(year) < 2000 || Number(year) > 2010) {
  84. item.remove()
  85. }
  86. }
  87.  
  88. // clean top250
  89.  
  90. // let movieList = document.querySelectorAll('ol.grid_view > li')
  91. // movieList.forEach(douban_delete_old)
  92.  
  93. addTraktLink()
  94. addDoubanLink()