您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Add RottenTomatoes Tomatometer rating info to IMDb pages
当前为
- // ==UserScript==
- // @name IMDb display RottenTomatoes info: redux
- // @namespace driver8.net
- // @version 0.1.1
- // @description Add RottenTomatoes Tomatometer rating info to IMDb pages
- // @author driver8
- // @match *://*.imdb.com/*
- // @grant GM_xmlhttpRequest
- // @grant GM_getValue
- // @grant GM_setValue
- // @grant GM_addStyle
- // @connect rottentomatoes.com
- // @require https://greasyfork.org/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 '';
- }
- };
- // Skip TV episodes
- function start() {
- let m = document.title.match(/\((?:TV\s+(?: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+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})`;
- let votesA = rtDiv.querySelector('a');
- votesA.href = 'https://www.rottentomatoes.com' + data.id;
- votesA.firstElementChild.innerText = data.rating;
- 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();
- })();