您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
Display RottenTomatoes Tomatometer rating info on IMDb pages
当前为
// ==UserScript== // @name IMDb display RottenTomatoes info: redux // @namespace driver8.net // @version 0.1.2 // @description Display RottenTomatoes Tomatometer rating info on IMDb pages // @author driver8 // @match *://*.imdb.com/* // @grant GM_xmlhttpRequest // @grant GM_getValue // @grant GM_setValue // @grant GM_addStyle // @connect rottentomatoes.com // @require http://greasyfork.icu/scripts/389810-rottentomatoes-utility-library/code/RottenTomatoes%20Utility%20Library.js?version=731014 // ==/UserScript== (function() { 'use strict'; console.log('hi imdb rt'); function parse(query, regex, doc) { doc = doc || document; try { let text = doc.querySelector(query).textContent.trim(); if (regex) { text = text.match(regex)[1]; } return text.trim(); } catch (e) { console.log('error', e); return ''; } }; function start() { let m = document.title.match(/\((?:TV\s+(?:Series|Mini-Series|Episode|Movie)\s*)?(\d{4})\s*(?:–|-)?\s*(?:\d{4})?\s*\)/); if (m) { let year = parseInt(m[1]); // Skip TV episodes if (!document.title.match(/\(TV\s+Episode/)) { let title = parse('.title_wrapper > h1', /([^()]+)/); let tv = document.title.match(/\(TV\s+(?:Mini-)?Series/) ? true : false; let id = title + year + (tv ? 'tv' : 'movie'); let data = GM_getValue(id, false); if (data) { console.log('Data EXISTS', data); displayData(data); } else { // Create spinner gif let imdbRating = document.querySelector('.imdbRating'); let spinnerDiv = imdbRating.cloneNode(false); //let spinnerDiv = document.createElement('div'); spinnerDiv.innerHTML = `<img src="${spinnerGif}">`; spinnerDiv.id = 'spinner-div'; imdbRating.parentNode.appendChild(spinnerDiv); getRtInfoFromTitle(title, tv, year).then((freshData) => { GM_setValue(id, freshData); spinnerDiv.parentNode.removeChild(spinnerDiv); displayData(freshData); }); } } } } function displayData(data) { let imdbRating = document.querySelector('.imdbRating'); let rtDiv = imdbRating.cloneNode(true); let icons = { 'fresh': 'url(https://www.rottentomatoes.com/assets/pizza-pie/images/icons/global/new-fresh-lg.12e316e31d2.png) no-repeat', 'certified': 'url(https://www.rottentomatoes.com/assets/pizza-pie/images/icons/global/cf-lg.3c29eff04f2.png) no-repeat', 'rotten': 'url(https://www.rottentomatoes.com/assets/pizza-pie/images/icons/global/new-rotten-lg.ecdfcf9596f.png) no-repeat', 'question': 'url(https://www.rottentomatoes.com/assets/pizza-pie/images/poster_default.c8c896e70c3.gif) no-repeat' // not used }; rtDiv.style.background = 'none'; for (let status in icons) { let regex = new RegExp(status); if (regex.test(data.state)) { rtDiv.style.background = icons[status]; } } rtDiv.style.backgroundSize = '28px'; rtDiv.title = data.consensus || ''; let ratingValue = rtDiv.querySelector('.ratingValue > strong'); //console.log(imdbRating, rtDiv, ratingValue); ratingValue.removeAttribute('title'); let scoreSpan = ratingValue.firstElementChild; scoreSpan.innerText = data.score || 'n/a'; scoreSpan.style.fontSize = '21px'; scoreSpan.style.lineHeight = '21px'; scoreSpan.style.color = data.state.match(/fresh/) ? '#BBFF88' : 'gray'; //'#f93109' : '#09c754'; // 'certified_fresh' ratingValue.nextSibling.innerText = '%'; ratingValue.nextSibling.style.color = scoreSpan.style.color; ratingValue.nextSibling.nextSibling.innerText = `(${data.votes || 0})`; let votesA = rtDiv.querySelector('a'); votesA.href = 'https://www.rottentomatoes.com' + data.id; votesA.firstElementChild.innerText = data.rating || 0; imdbRating.parentNode.appendChild(rtDiv); if (data.consensus) { let titleBlock = document.querySelector('.title_block'); let consDiv = document.createElement('div'); consDiv.classList.add('consensus-div'); consDiv.innerHTML = '<p>' + data.consensus + '</p>'; titleBlock.after(consDiv); } } GM_addStyle(` .consensus-div { margin: 10px; } .consensus-div p { background-color: #444; color: #FFF; border-radius: 5px; padding: 3px 5px 3px 5px; font-size: 1em; } #spinner-div { background: none; } .heroic-overview .title_block { padding-bottom: 0px; } `); var spinnerGif = ``; start(); })();