IMDb display RottenTomatoes info: redux

Add RottenTomatoes Tomatometer rating info to IMDb pages

目前為 2019-09-06 提交的版本,檢視 最新版本

// ==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();
})();