Greasy Fork

Greasy Fork is available in English.

bangumi收藏列表显示Rank

在用户的收藏列表下显示作品的排名并高亮显示 100以内为深蓝色 1000以内背景为绿色 1000~2000为蓝色 2000外为红色 没上榜的为黑色

当前为 2017-10-17 提交的版本,查看 最新版本

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         bangumi收藏列表显示Rank
// @namespace    https://github.com/bangumi/scripts/liaune
// @version      0.1.3
// @description  在用户的收藏列表下显示作品的排名并高亮显示 100以内为深蓝色 1000以内背景为绿色 1000~2000为蓝色 2000外为红色 没上榜的为黑色
// @author       Yonjar,Liaune
// @match        http://bgm.tv/*/list/*
// @match        http://bgm.tv/index/*
// @match        https://bgm.tv/*/index/*
// @match        http://bangumi.tv/*/list/*
// @match        http://chii.in/*/list/*
// @match        https://bgm.tv/*/list/*
// @match        https://bangumi.tv/*/list/*
// @match        https://chii.in/*/list/*
// @grant        GM_addStyle
// ==/UserScript==

GM_addStyle(`
    .yonjar_bgm_userjs_rank_excellent{
        background-color: #0033CC!important;
    }
    .yonjar_bgm_userjs_rank_recommended{
        background-color: #3ed715!important;
    }

    .yonjar_bgm_userjs_rank_refuse{
        background-color: red!important;
    }

    .yonjar_bgm_userjs_rank_undefined{
        background-color: black!important;
    }

    .yonjar_bgm_userjs_rank_btn{
        display: inline-block;
        color: #666;
        text-shadow: 0px 1px 2px #FFF;
        text-decoration: none;
        line-height: 20px;
        margin: 0 5px 5px 0;
        padding: 0 12px;
        border: 1px solid #DDD;
        background: -webkit-gradient(linear,left top,left bottom,from(#FCFCFC),to(#F1F1F1));
        background: -moz-linear-gradient(top,#FCFCFC,#F1F1F1);
        background: -o-linear-gradient(top,#FCFCFC,#F1F1F1);
        -webkit-box-shadow: 0 1px 2px #EEE,inset 0 1px 1px #FFF;
        -moz-box-shadow: 0 1px 2px #EEE,inset 0 1px 1px #FFF;
        box-shadow: 0 1px 2px #EEE,inset 0 1px 1px #FFF;
        -moz-border-radius: 4px;
        -webkit-border-radius: 4px;
        border-radius: 4px
    }
    .yonjar_bgm_userjs_rank_btn:hover {
        color: #FFF;
        text-shadow: none;
        background: #4F93CF;
        background: -moz-linear-gradient(top,#6BA6D8,#4F93CF);
        background: -o-linear-gradient(top,#6BA6D8,#4F93CF);
        background: -webkit-gradient(linear,left top,left bottom,from(#5FA3DB),to(#72B6E3));
        -webkit-box-shadow: 0 0 3px #EEE,inset 0 -1px 5px rgba(0,0,0,0.1);
        -moz-box-shadow: 0 0 3px #EEE,inset 0 -1px 5px rgba(0,0,0,0.1);
        box-shadow: 0 0 3px #EEE,inset 0 -1px 5px rgba(0,0,0,0.1)
    }
`);
let itemsList = document.querySelectorAll('#browserItemList li.item');

function removeSelf(){
    this.parentNode.removeChild(this);
}

function showRank(href, index){
    fetch(href)
        .then(data => {
            return new Promise(function (resovle, reject) {
                let targetStr = data.text();
                resovle(targetStr);
            });
        })
        .then(targetStr => {
            let canMatch = targetStr.match(/<small class="alarm">#(\S+?)<\/small>/);
            let rankNum =  canMatch ? parseInt(canMatch[1], 10) : 'NULL';
            let rankSp = document.createElement('span');
            rankSp.className = 'rank';
            if (rankNum <= 100) {
                rankSp.classList.add('yonjar_bgm_userjs_rank_excellent');
            }
            else if (rankNum <= 1000) {
                rankSp.classList.add('yonjar_bgm_userjs_rank_recommended');
            }
            else if (rankNum >= 2000) {
                rankSp.classList.add('yonjar_bgm_userjs_rank_refuse');
            }
            else if (rankNum === 'NULL') {
                rankSp.classList.add('yonjar_bgm_userjs_rank_undefined');
            }

            rankSp.innerHTML = `<small>Rank </small>${rankNum}`;

            document.querySelectorAll('#browserItemList .item .inner')[index].insertBefore(rankSp, document.querySelectorAll('#browserItemList .item .inner .info.tip')[index]);
        });
}

itemsList.forEach( (elem, index) => {
    let href = elem.querySelector('a.subjectCover').href;
//    let container = elem.querySelector('.inner ul.collectMenu') || elem.querySelector('.inner .collectBlock');
//    let li = document.createElement('li');
//    let showBtn = document.createElement('button');
    showRank(href,index);
//    showBtn.addEventListener('click', showRank.bind(this, href, index), false);
//    showBtn.addEventListener('click', removeSelf, false);
//    showBtn.className = 'yonjar_bgm_userjs_rank_btn';
//    showBtn.textContent = 'Rank';
//    li.append(showBtn);
//    container.append(li);
});