Greasy Fork is available in English.

巴哈姆特-場外休憩區--隱藏廢文

作者:hbl91707(深海異音)

// ==UserScript==
// @name        巴哈姆特-場外休憩區--隱藏廢文
// @namespace   hbl917070
// @include     https://forum.gamer.com.tw/C.php?bsn=60076*
// @include     https://forum.gamer.com.tw/Co.php?bsn=60076*
// @include     https://forum.gamer.com.tw/C.php?page=*&bsn=60076*


// @version     1.41
// @grant       none
// @description         作者:hbl91707(深海異音)
// @description:zh-tw   作者:hbl91707(深海異音)
// ==/UserScript==
//

/*

巴哈姆特-場外休憩區--隱藏廢文
更新日期:2018-04-13

說明:
  1.可設定【回文】小於幾個字就不顯示。
  2.可設定【留言】小於幾個字就不顯示。
  3.可設定特定的文字不顯示,例如回文or留言只有一個【卡】,就不顯示。
  4.網頁最上方會顯示隱藏的回文與留言數量。點擊後可以解除隱藏,並且會變成紅色背景以方便檢查。


作者小屋:
http://home.gamer.com.tw/homeindex.php?owner=hbl917070

*/

//-------------------------------------------------------------

//小於等於特定的字數就隱藏
var int_回文小於特定長度 = 0;
var int_留言小於特定長度 = 0;


//在判斷長度是否會被過濾之前,會先隱藏這裡的文字
//例如:【私私 推】雖然有4個字,但是實際上長度是0,因為【推】跟【私】跟【空白】會被無視
var s_過濾特定文字 = [
    /通知/g, /再說/g, /在說/g, /形狀/g, /老婆/g, /拜託/g, /總之/g, /化成/g, /留名/g,
    /對不起/g, /收到/g, /造福/g, /好奇/g, /自推/g, /再推/g, /再啦/g, /在啦/g, /好屌/g,
    /神串/g, /上香/g, /前排/g,  /神串/g, /不送/g, /慢走/g,

    /ㄅ/g, /ㄈ/g, /ㄍ/g, /ㄊ/g, /ㄌ/g, /ㄙ/g, /ㄏ/g, /ㄓ/g, /ㄛ/g,
    /bang/ig, /rip/ig, /car/ig,
    /c/ig, /a/ig, /r/ig, /g/ig, /i/ig, /n/ig, /d/ig, /e/ig, /x/ig, /d/ig, /w/ig,

    /私/g, /斯/g, /濕/g, /絲/g, /司/g, /禾/g, /厶/g, /死/g, /上/g, /我/g, /惹/g, /嘻/g,
    /車/g, /香/g, /先/g, /穴/g, /好/g, /啦/g, /拉/g, /斷/g, /火/g, /喔/g, /來/g, /吧/g,
    /啊/g, /阿/g, /的/g, /個/g, /求/g, /哦/g, /乃/g, /感/g, /恩/g, /謝/g, /蓋/g, /懂/g,
    /棒/g, /硬/g, /爆/g, /推/g, /卡/g, /看/g, /幹/g, /豪/g, /了/g, /甲/g, /大/g, /啪/g,
    /野/g, /狂/g, /笑/g, /真/g, /想/g, /舔/g, /噓/g, /分/g, /糞/g, /怕/g, /嗎/g, /射/g,
    /滑/g, /倒/g, /嗯/g, /首/g, /雷/g, /電/g, /郭/g, /嘓/g, /屌/g, /哇/g, /酷/g, /神/g,
    /猛/g, /屌/g, /太/g, /欸/g, /掰/g, /鬧/g, /挖/g,

    /8/g, /7/g, /1/g, /0/g,
    /^\s+|\s+$/g, /\r/g, /\n/g, /[.]/g, /[=]/g, /[?]/g, /[+]/g, /%/g, /[,]/g, /~/g, /!/g,
    /?/g, /%/g, /…/g, /。/g, /,/g, /!/g, /~/g, / /g , /\\/g , /\|/g , /\//g
];

//-------------------------------------------------------------


var int_留言 = 0;//記錄次數
var int_回文 = 0;


//產生【顯示】的按鈕
var bu = document.createElement("div");
bu.id = "but_view";
bu.onclick = fun_顯示;
bu.style.display = "block";
bu.style.float = "left";
bu.style.margin = "5px";
//bu.style.position = "fixed";
//bu.style.left = "270px";
//bu.style.top = "10px";
bu.style.color = "rgb(255,150,150)";
bu.style.zIndex = "5000000";

bu.style.backgroundColor = "rgba(0,0,0,0.3)";
bu.style.padding = "0px";
bu.style.border = "#fff solid 0px";


var obj_搜尋框 = undefined;
try {
    obj_搜尋框 = document.getElementsByClassName("logo")[0].parentNode;
} catch (e) { }

if(obj_搜尋框 === undefined){
    obj_搜尋框 = document.body;
    bu.style.position = "fixed";
    bu.style.left = "0px";
    bu.style.top = "0px";
}
obj_搜尋框.appendChild(bu);



//隱藏回文
var obj_1 = document.getElementsByClassName("c-post");
for (var i = 0; i < obj_1.length; i++) {



    //檢查是否有展開留言的按鈕
    try {
        var obj_展開留言 = obj_1[i].getElementsByClassName("more-reply")[0];

        (function(){
           var ac = obj_展開留言.onclick;//複製原本展開留言的function
           obj_展開留言.onclick = function(){
               ac();
               setTimeout(function () {
                   fun_隱藏留言();
               }, 1800);

           };
        })()

    } catch (e) { }


    var s = obj_1[i].getElementsByClassName("c-article")[0].innerText;

    //刪除無意義的文字
    if (s.length < 50)
        for (var k = 0; k < s_過濾特定文字.length; k++) {
            if (s.length <= int_回文小於特定長度)
                break;
            s = s.replace(s_過濾特定文字[k], "");
        }

    //過濾過短的文字
    if (obj_1[i].getElementsByClassName("c-article")[0].getElementsByTagName("img")[0] === undefined)
        if (obj_1[i].getElementsByClassName("c-article")[0].getElementsByTagName("iframe")[0] === undefined)
            if (s.length <= int_回文小於特定長度) {
                fun_隱藏物件(obj_1[i].parentNode, "回文");
                continue;
            }

}


fun_隱藏留言();



function fun_隱藏留言() {

        var obj_1 = document.getElementsByClassName("c-reply__item");
        for (var i = 0; i < obj_1.length; i++) {

            //取得留言內容
            var s = obj_1[i].getElementsByClassName("c-article")[0].innerText;

            if (s.length < 20)
                for (var k = 0; k < s_過濾特定文字.length; k++) {
                    if (s.length <= int_留言小於特定長度)
                        break;
                    s = s.replace(s_過濾特定文字[k], "");
                }


            if (obj_1[i].getElementsByClassName("c-article")[0].getElementsByTagName("img")[0] === undefined)
                if (obj_1[i].getElementsByClassName("c-article")[0].getElementsByTagName("iframe")[0] === undefined)
                    if (s.length <= int_留言小於特定長度) {
                        fun_隱藏物件(obj_1[i], "留言");
                        continue;
                    }


    }//for

    fun_更新按鈕();


}






function fun_隱藏物件(obj, ss) {
    if (obj.style.display != "none") {

        obj.style.display = "none";
        obj.style.backgroundColor = "rgba(150,10,20,0.3)";

        if (ss == "留言") {
            int_留言++;
        } else {
            int_回文++;
        }
    }
}


function fun_更新按鈕() {

    if (int_留言 === 0 && int_回文 === 0) {
        document.getElementById("but_view").innerHTML = "";
    } else if (int_回文 === 0) {
        document.getElementById("but_view").innerHTML = "顯示:留言" + int_留言;
    } else if (int_留言 === 0) {
        document.getElementById("but_view").innerHTML = "顯示:回文" + int_回文;
    } else {
        document.getElementById("but_view").innerHTML = "顯示:留言" + int_留言 + "、回文" + int_回文;
    }

}






//hover
try{
    $("#but_view").hover(function(){
        $("#but_view").css("color","#117E96");
    },function(){
        $("#but_view").css("color","rgb(255,150,150)");
    });
}catch(e){}

fun_更新按鈕();


function fun_顯示() {

    //初始化
    document.getElementById("but_view").innerHTML = "";
    int_回文 = 0;
    int_留言 = 0;

    //回文
    var obj_1 = document.getElementsByClassName("c-post");
    for (var i = 0; i < obj_1.length; i++) {
        obj_1[i].parentNode.style.display = "block";
    }

    //留言
    obj_1 = document.getElementsByClassName("c-reply__item");
    for (i = 0; i < obj_1.length; i++) {
        obj_1[i].style.display = "block";
    }
}