Greasy Fork is available in English.

Acfun屏蔽计划

帮助你屏蔽不想看的UP主

Stan na 04-07-2019. Zobacz najnowsza wersja.

// ==UserScript==
// @name         Acfun屏蔽计划
// @namespace    http://tampermonkey.net/
// @version      1.505
// @description  帮助你屏蔽不想看的UP主
// @author       人文情怀
// @match        http://www.acfun.cn/a/ac*
// @match        http://www.acfun.cn/v/list63
// @match        https://www.acfun.cn/a/ac*
// @match        http://www.acfun.cn/*
// @match        https://www.acfun.cn/*
// @match        https://www.acfun.cn/v/list*
// @match        http://www.acfun.cn/a/ac*
// @match        https://www.acfun.cn/a/ac*
// @match        http://www.acfun.cn/v/ac*
// @match        https://www.acfun.cn/v/ac*
// @match        https://www.acfun.cn/v/as*
// @match        http://www.acfun.cn/v/as*
// @connect      greasyfork.org
// @require      https://code.jquery.com/jquery-3.4.1.min.js
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM.getValue
// @grant        GM.setValue
// @grant        GM_xmlhttpRequest
// @grant        GM.xmlHttpRequest
// @grant        unsafeWindow
// @run-at      document-idle
// ==/UserScript==

function injectStyles(rule) {
    var div = $("<div />", {
        html: '&shy;<style>' + rule + '</style>'
    }).appendTo("body");
}

injectStyles(`
div.panel-background-color{
    background-color: rgb(255, 241, 242);
}

div.ctabs{
    position:relative;
    height: 28px;
    /* border-bottom: solid white 1px; */
    font-size: 13px
}
a.ctab{
    white-space:nowrap;
    user-select:none;
    padding: 1px;
    margin: 1px 1px 0px 1px;
    position:relative;
    display: inline-block;
    width: 50px;
    height: 25px;
    font-size: 15px;
    z-index: 9999;
    background-color: #f0b0b0;
    color: #4f2e10;
    border-style:solid;
    border-color: white;
    text-align:center;
}
a.ctab-focus{
    background-color: #ececec;
    transform: translate(0, 3px);
}


`);
injectStyles(`
.blockname{
    font-size:13px;
    display:inline-block;
    margin:2px;
    height:18px;
    background-color:white;
}
.blockdel{
    width:18px;
    height:18px;
    line-height:18px;
    padding: 2px;
    background-color: rgb(255,120,120);
    border-width:0;
    font-size:15px;
    margin-left: 4px;
}
`);

injectStyles(`
button.disabled{
    cursor: not-allowed;
    pointer-events: none;
    /*Button disabled - CSS color class*/
    color: #c0c0c0;
    background-color: #ffffff;
}`);

injectStyles(`
        .filter-button{
           width: 15px;
           height: 15px;
           background-color: rgba(255,0,0,1);
           padding: 1.5px;
           left :0;
           top:0;
           transform: translate(0,0);
           display: none;
           position: absolute;
           z-index: 99999;
           background-size: contain;
           background-image: url();
           border-radius: 11px;
           border: 2px rgb(230,230,230) solid;
           cursor: pointer;
        }
        `);

function core() {
    'use strict';
    let version = "1.505";
    let empty = (a) => {
        return typeof a === "undefined" ? () => {
        } : a;
    };

    let GM_set = typeof GM_setValue === "undefined" ?
        function (key, value, callback, failcallback) {
            let p = GM.setValue(key, value);
            p.then(empty(callback), empty(failcallback));


        }
        : function (key, value, callback) {
            let res = GM_setValue(key, value);
            callback();
        };


    let GM_get = typeof GM_getValue === "undefined" ?
        function (key, value, callback) {
            let p = GM.getValue(key, value);
            p.then((debug) => {
                empty(callback)(debug);
            }, () => {
                callback(value);
            });
            //console.log("empty", empty(callback));
        }
        : function (key, value, callback, failcallback) {
            let res = GM_getValue(key, value);
            callback(res);
        };

    //清空列表。DEBUG用
    function cleanList() {

        GM_set("ACFUN_BLOCK_LIST", []);
        GM_set("ACFUN_BLOCK_KEYWORDS", []);
    }

    let ups = function (callback) {
        GM_get("ACFUN_BLOCK_LIST", [], callback);
    };

    let keywords = function (callback) {
        GM_get("ACFUN_BLOCK_KEYWORDS", [], callback);
    };

    let repliers = function (callback) {
        GM_get("ACFUN_BLOCK_REPLIERS", [], callback);
    };

    let setUp = function (d, callback) {
        GM_set("ACFUN_BLOCK_LIST", d, callback);
    };

    let setKeywords = function (d, callback) {
        GM_set("ACFUN_BLOCK_KEYWORDS", d, callback);
    };

    let setRepliers = function (d, callback) {
        GM_set("ACFUN_BLOCK_REPLIERS", d, callback);
    };

    function setUpdateTime(time, callback) {
        let t = typeof time === "undefined" ? +new Date() : time;
        GM_set("UPDATE_TIME", t, () => {
            empty(callback)(t);
        });
    }

    function getUpdateTime(callback) {
        let time = 0;
        GM_get("UPDATE_TIME", time, (d) => {
            console.log("get update time", d, parseInt(d));
            callback(parseInt(d));
        });
    }

    function addToUpList(id, callback) {
        ups((old) => {
            if (old.indexOf(id) >= 0) {
                $.info.show("你已经屏蔽过UP主[" + id + "]啦!");
                return;
            }
            old.push(id);
            GM_set("ACFUN_BLOCK_LIST", old, () => {
                $.info.show("已将UP主[" + id + "]加入屏蔽列表");
                empty(callback)();
                setUpdateTime();
            });
        });
    }


    function removeFromUpList(id, callback) {
        ups((old) => {
            let i = old.indexOf(id);
            if (i >= 0) {
                old.splice(i, 1);
            }
            GM_set("ACFUN_BLOCK_LIST", old, () => {
                $.info.show("已将UP主[" + id + "]移出屏蔽列表。");
                empty(callback)();
                setUpdateTime();
            });
        });
    }

    function addToKeywords(id, callback) {
        keywords((old) => {
            if (old.indexOf(id) >= 0) {
                $.info.show("你已经添加过关键词[" + id + "]啦!");
                return;
            }
            old.push(id);
            GM_set("ACFUN_BLOCK_KEYWORDS", old, () => {
                $.info.show("已将关键词[" + id + "]加入屏蔽列表");
                empty(callback)();
                setUpdateTime();
            });
        });
    }

    function removeFromKeywords(id, callback) {
        keywords((old) => {
            let i = old.indexOf(id);
            if (i >= 0) {
                old.splice(i, 1);
            }
            GM_set("ACFUN_BLOCK_KEYWORDS", old, () => {
                $.info.show("已将关键词[" + id + "]移出屏蔽列表。");
                empty(callback)();
                setUpdateTime();
            });
        });
    }

    function addToRepliers(id, callback) {
        repliers((old) => {
            if (old.indexOf(id) >= 0) {
                $.info.show("你已经屏蔽过评论者[" + id + "]啦!");
                return;
            }
            old.push(id);
            GM_set("ACFUN_BLOCK_REPLIERS", old, () => {
                $.info.show("已将评论者[" + id + "]加入屏蔽列表");
                empty(callback)();
                setUpdateTime();
            });
        });
    }

    function removeFromRepliers(id, callback) {
        repliers((old) => {
            let i = old.indexOf(id);
            if (i >= 0) {
                old.splice(i, 1);
            }
            GM_set("ACFUN_BLOCK_REPLIERS", old, () => {
                $.info.show("已将评论者[" + id + "]移出屏蔽列表。");
                empty(callback)();
                setUpdateTime();
            });
        });
    }

    let filterButton = document.createElement("div");

    function initButton() {
        document.body.appendChild(filterButton);

        $(filterButton).attr("class", "filter-button")

    }


    function handleSpecialJSONstr(str) {
        let str2 = str.replace("\n", "");
        let matches = str2.match(/\"title\"\:\"(.{0,55})\"\,"[a-zA-Z]{1,15}":/);

        if (matches !== null && matches.length > 0) {
            let title = matches[1];
            let res = str.replace(title, "");

            return [res, title];
        } else {
            return [str2, "无标题"];
        }

    }

    //获得所有主页的UP的DOM TAG
    function getHomeSelection() {
        let res = [];
        //过滤主页视频
        let selections = $("a[data-info]");
        for (let i = 0; i < selections.length; i++) {
            let tag = selections[i];
            let info = $(tag).attr("data-info");
            let json = "";
            try {
                let temp = (info);
                json = JSON.parse(temp);
                let title = json.title;
                let username = json.userName;
                res.push({tag: $(tag).parent()[0], title: title, username: username, type: 1, json: json});
            } catch (e) {
                console.error(e);
            }

            //$(tag)
        }

        //过滤右边排行榜视频
        let sel = $("ul[data-con]");

        //For each rank
        for (let i = 0; i < sel.length; i++) {
            let tag = sel[i];
            let rows = $(tag).find("li");
            //For each row
            for (let ri = 0; ri < rows.length; ri++) {
                let rowTag = rows[ri];
                let aTag = $(rowTag).find("[title]")[0];
                let title = $(aTag).attr("title");
                let matches = usernameByTitle(title);
                let titlestr = titleByTitle(title)[0];
                if (matches) {
                    let username = matches[0].substring(3).trim();
                    res.push({tag: rowTag, title: titlestr, username: username, type: 2});
                }
            }
        }
        //--------------------主页文章区
        sel = $("div[data-con]");
        for (let i = 0; i < sel.length; i++) {
            let tag = sel[i];
            let rows = $(tag).find("li");
            //For each row
            for (let ri = 0; ri < rows.length; ri++) {
                let rowTag = rows[ri];
                let aTag = $(rowTag).find("[title]")[0];
                let title = $(aTag).attr("title");
                if (title) {
                    let matches = usernameByTitle(title);
                    let titlestr = titleByTitle(title)[0];
                    if (matches) {
                        let username = matches[0].substring(3).trim();
                        res.push({tag: rowTag, title: titlestr, username: username, type: 3});

                    }
                }
            }
        }
        //香蕉搒
        var allBananas = $("figure.fl.block-box.block-video.weblog-item").find("> figcaption > em > a");
        for (let i = 0; i < allBananas.length; i++) {
            let sel = allBananas[i];
            let upname = $(sel).attr("title");
            let tag = $(sel).parent().parent().parent()[0];
            let title = $(sel).parent().parent().find('b > a').text();
            res.push({tag: tag, username: upname, type: 1, title: title});
        }

        //大版推荐
        let allBig = $('.module-video-big').find('.text-overflow').find('a[title]');
        for (let i = 0; i < allBig.length; i++) {
            try{
            let title = $(allBig[i]).attr("title");
            let regx = /UP:(.+)/;
            let r = regx.exec(title);
            let username = r[1];
            let tag = $(allBig[i]).parent().parent();
            let subtag = tag.prev();
            let titlestr = titleByTitle(title)[0];
            res.push({tag: subtag[0], subtag: tag[0], username: username, type: 5, title: titlestr});
            }catch(e){

            }

        }
        // console.log("res",res);
        return res;
    }

    function getListSelection() {
        console.log("list selec");
        let res = [];
        let sel = $("div.weblog-item");
        for (let i = 0; i < sel.length; i++) {
            let row = sel[i];
            let aTag = $(row).find(".atc-up")[0];
            let username = $(aTag).attr("title");
            let title = $(row).find('a[title]').attr("title");
            res.push({tag: row, username: username, type: 4, title: title});

        }
        //Video List
        let sel2 = $("li.weblog-item");
        //console.log(sel2);
        for (let i = 0; i < sel2.length; i++) {

            let row = sel2[i];
            //console.log(row);
            let title = $(row).find("b.text-over").find('.third-title').text();
            let username = $(row).find("p.up-name").find('a.third-name').text();
            res.push({tag: row, username: username, type: 4, title: title});
        }
        //console.log(res);
        return res;
    }

    let pageType = "home";

    //显示/刷新屏蔽的UP主
    function displayUpList() {


        ups((data) => {
            //console.log("up",data);
            $("#upnameList").empty();
            for (let i = 0; i < data.length; i++) {

                let style2 = "";
                let b = $("<div class='blockname'><span>" + data[i] + "</span></div>");
                let del = $("<button class='blockdel' >×</button>");
                b.append(del);
                let str = data[i];
                del.on("click", function () {
                    removeFromUpList(str, () => {
                        displayUpList();
                        if (pageType === "home") {
                            FilterHomePage();
                        } else if (pageType === "list") {
                            FilterListPage();
                        }
                    });

                });
                $("#upnameList").append(b);
            }

        });
    }


    //显示屏蔽的关键词
    function displayKeywords() {
        keywords((data) => {
            $("#keywords_list").empty();
            for (let i = 0; i < data.length; i++) {
                let b = $("<div class='blockname'><span>" + data[i] + "</span></div>");
                let del = $("<button class='blockdel' >×</button>");
                b.append(del);
                let str = data[i];
                del.on("click", function () {
                    removeFromKeywords(str, () => {
                        displayKeywords();
                        if (pageType === "home") {
                            FilterHomePage();
                        } else if (pageType === "list") {
                            FilterListPage();
                        }
                    });

                });
                $("#keywords_list").append(b);
            }
        })
    }

    //显示屏蔽的评论者
    function displayRepliers() {
        repliers((data) => {
            $("#repliersList").empty();
            for (let i = 0; i < data.length; i++) {
                let b = $("<div class='blockname'><span>" + data[i] + "</span></div>");
                let del = $("<button class='blockdel' >×</button>");
                b.append(del);
                let str = data[i];
                del.on("click", function () {
                    removeFromRepliers(str, () => {
                        displayRepliers();
                        filterReplies();
                    });

                });
                $("#repliersList").append(b);
            }
        })
    }


    //检查公告
    function checkAnnouncement(callback) {
        let xhttp = typeof GM_xmlhttpRequest !== "undefined" ? GM_xmlhttpRequest : GM.xmlHttpRequest;
        xhttp({
            method: "GET",
            url: "https://greasyfork.org/scripts/384697-acfunblockerannoucement/code/AcfunBlockerAnnoucement.js",
            onload: function (response) {
                let text = response.responseText;
                callback(text);
            },
            onerror(evt) {
                callback(null);
            }
        });
    }

    //检查更新
    function checkUpdate(callback) {
        let xhttp = typeof GM_xmlhttpRequest !== "undefined" ? GM_xmlhttpRequest : GM.xmlHttpRequest;
        xhttp({
            method: "GET",
            url: "https://greasyfork.org/scripts/381476-acfun%E8%BF%87%E6%BB%A4up%E8%AE%A1%E5%88%92/code/Acfun%E8%BF%87%E6%BB%A4UP%E8%AE%A1%E5%88%92.user.js",
            onload: function (response) {
                let text = response.responseText;
                let p = /@version +(\d+\.\d+)/;
                let arr = p.exec(text);
                let latest = arr[1];
                callback(latest);
            }
        });
    }

    let show = false;
    let dragging = false;

    function banana(i) {
        let banana_0 = "url()";
        let res = "<div id='banana_" + i + "'class='bbanana' style='cursor: pointer;display:inline-block;height:20px; width:20px; background-image:" + banana_0 + ";background-position: center; background-repeat:no-repeat; background-size:contain'></div>";
        return res
    }

    let articleId = 10271618;

    function feedBanana(n) {
        try {
            //let a = btoa(Math.random().toString(36).substr(2))
            //let str = '$.cookie("stochastic","'+a+'",{path:"/"});';
            //console.log(str);
            //unsafeWindow.eval();
            //let cookie = unsafeWindow.eval('(()=>{return })();');
            let command = `
let a = btoa(Math.random().toString(36).substr(2));
$.cookie("stochastic",a ,{path:"/"});
let c = $.cookie("_did");
$.ajax({
type:"post",
url: "/nd/pst?locationPath=throwBanana&certified="+a,
beforeSend: function(e) {
e.setRequestHeader("udid", c)
},
data: {
contentId: "` + articleId + `",
count: ` + (n + 1) + `,
userId: $.user.uid,
},
dataType: "json",
xhrFields: {
withCredentials: !0
}
}).done(function(e){
if (e.success>0){
$.info.success("成功投食了作者"+` + (n + 1) + `+"根香蕉O(∩_∩)O。谢谢支持!", 3e3)
}else{
$.info.warning("投食作者失败了。"+e.info, 3e3);
}
}).fail(function(){
$.info.warning("投食作者失败了 /(ㄒoㄒ)/~~。请于稍后重新操作。", 3e3)
})`;

            unsafeWindow.eval(command);

        } catch (e) {
            console.log("投食DEBUG", e);
        }

    }

    let banana_n = -1;

    function attachBananaEvent() {

        let banana_0 = "url()";
        let banana_1 = "url()";
        $(".bbanana").on("mouseover", function () {
            let id = $(this).attr("id");
            let n = parseInt(id.split("_")[1]);
            banana_n = n;
            let all = $(".bbanana");
            for (let i = 0; i < all.length; i++) {
                let tid = $(all[i]).attr("id");
                let tn = parseInt(tid.split("_")[1]);
                if (tn <= n) {
                    $(all[i]).css("background-image", banana_1)
                } else {
                    $(all[i]).css("background-image", banana_0)
                }
            }

        })
            .on("click", function () {

                let id = $(this).attr("id");
                let n = parseInt(id.split("_")[1]);
                feedBanana(n);
            });
        $("#banana_contain").on("mouseleave", function () {
            $(".bbanana").css("background-image", banana_0)
        })
    }

    function bindKeywordInputs() {
        $('#keyword').keypress(function (e) {
            if (e.keyCode === 13)
                $('#enterKeyword').click();
        });

        $('#enterKeyword').on("click", function () {
            let val = $("#keyword").val();
            if (val.length > 1) {
                $("#keyword").val('');
                addToKeywords(val, () => {
                    displayKeywords();
                    if (pageType === "home") {
                        FilterHomePage();
                    } else if (pageType === "list") {
                        FilterListPage();
                    }
                });
            } else {
                $.info.warning('不能添加过短的关键词。');
            }
        })
    }

    function checkBananaFed() {
        let url = 'https://www.acfun.cn/member/collect_up_exist.aspx?contentId=' + articleId;
        $.ajax({url: url})
            .done(function (d) {
                //console.log(d);
                if (d.result && d.result === "请先登录") {
                    $("#banana_contain").text("登录投蕉吧!")
                } else {
                    if (d.data && d.data.banana) {
                        if (d.data.banana > 0) {
                            $("#banana_contain").text("感谢" + d.data.banana + "蕉支持!");
                        }
                    }
                }

            })

    }

    function addPanel() {


        let dx = 0;
        let dy = 0;
        let sx = 0;
        let sy = 0;
        let ox = 0;
        let oy = 0;


        injectStyles(`

        div.panel-drag-image{
            height: 92px;
            left: 22px;
            width: 66px;
            background-image:  url();
            background-size:contain;
            background-repeat: no-repeat;
            position:absolute
        }
        button.panel-toggle{
            height: 92px;
            width: 23px;
            background-color: rgb(255,193,193);
            border-width: 0;
        }
        div.panel-wrap{
            z-index: 999;
            position: fixed;
            left: 0;
            top: 0;
            text-orientation: upright;
        }
        div.panel-toggle-wrap{
            position: relative;
            height: 92px;
            width: 23px
        }
        div.panel-content-container{
            width: 280px;
            display:none;
            padding: 0px;
            z-index:998;
            position:fixed;
            background-color:rgb(255, 196, 196);
            left:23px;
            top: 0px;
        }
        div.upnames-list{
            height: 220px; border: 0px solid white; margin: 3px;overflow-y:scroll
        }
        div.keywords-list{
            height: 220px;
            border: 0px solid white;
            margin: 3px;
            overflow:hidden;
            display:none;
        }
        div.repliers-list{
            height: 220px;
            border: 0px solid white;
            margin: 3px;
            overflow:hidden;
            display:none;
        }
        div.keywords-input-wrap{
            height: 22px;
            background-color:
            rgb(220,220,220);
        }
        input.keyword-input{
            height: 18px;width: 120px; border: 0 solid black; padding: 0; margin: 1px;
        }
        input.keyword-submit{
            line-height:18px; height: 18px;width: 60px; border: 1px solid grey; margin: 1px; padding: 0; background-color: rgb(179, 255, 179)
        }
        div.announcement{
            background-color:black; color: white;height: 220px; border: 0px solid white; margin: 3px;overflow-y:scroll; display:none;
        }
        div.cloud-panel{
            color: black; height: 220px; border: 0px solid white; margin: 3px; display:none;
        }

        `);

        let panelWrap = $("<div id='blockbuttoncontainer' class='panel-wrap'></div>");
        let panelToggleWrap = $("<div class='panel-toggle-wrap'></div>");
        panelWrap.append(panelToggleWrap);

        let panelToggleButton = $("<button id='blockbutton' class='panel-toggle'>屏蔽设置</button>");
        let panelDragImage = $("<div class='panel-drag-image'></div>");
        //panel container
        panelToggleWrap.append(panelDragImage);

        let panelContentContainer = $("<div id='blockpanel' class='panel-content-container'></div>");

        let ptabs = $("<div id='tabs' class='ctabs'></div>");
        let tab_1 = $("<a class='ctab ctab-focus'>UP主</a>");
        let tab_2 = $("<a class='ctab'>评论者</a>");
        let tab_3 = $("<a class='ctab'>关键字</a>");
        let tab_4 = $("<a class='ctab' >云备份</a>");
        let tab_5 = $("<a class='ctab'>公告</a>");


        let panelUpNames = $("<div id='upnameList'  class='upnames-list panel-background-color'></div>"); //1
        let panelRepliers = $("<div id='repliersList'  class='repliers-list panel-background-color'></div>"); //2
        let panelKeywords = $(`<div id='keywordsList'  class='keywords-list panel-background-color'>
                <div class="keywords-input-wrap">
                    <input class="keyword-input" id='keyword' type='text' autocomplete="off" />
                    <input class="keyword-submit" id='enterKeyword' type='submit' value='添加↵'/>
                </div>
                <div id='keywords_list' style='height: 198px;overflow-y: scroll; '></div>
            </div>`); //3
        let panelCloud = $("<div id='cloudpanel' class='cloud-panel panel-background-color'></div>"); //4
        let panelAnnouncement = $("<div id='announcement' class='announcement'>正在加载公告....</div>");//5

//bind tabs

        tab_1[0]["tabBind"] = panelUpNames;
        tab_2[0]["tabBind"] = panelRepliers;
        tab_3[0]["tabBind"] = panelKeywords;
        tab_4[0]["tabBind"] = panelCloud;
        tab_5[0]["tabBind"] = panelAnnouncement;


        ptabs.append(tab_1);
        ptabs.append(tab_2);
        ptabs.append(tab_3);
        ptabs.append(tab_4);
        ptabs.append(tab_5);


        let cloudInfo = $("<div style='padding:8px;'>本插件利用Acfun的私信系统实现云备份屏蔽设置。登陆后即可随时同步你的屏蔽设置。每次Acfun页面打开时将会自动检查和同步哟!</div>");
        let cloudCheckTime = $("<div id='checktime' style='display: none'></div>");
        let cloudSyncButton = $("<div style='padding: 8px;'><button id='cloudsync' class='disabled' style='padding: 5px; font-size: 23px; width: 150px'>正在同步...</button></div>");
        panelCloud.append(cloudInfo);
        panelCloud.append(cloudSyncButton);
        panelCloud.append(cloudCheckTime);


        let advertisementInfo = $("<div style='border: 1px solid white; margin:3px;padding: 2px; font-size: 11px;background-color:rgb(255, 217, 67); color: black'>喜欢的话 安利哟:<a id='articleRec' target='_blank' style='color:rgb(71, 71, 138); text-decoration: underline' href='/a/ac10271618'>ac10271618</a></div>");
        let bananaHTML = "<a id='banana_contain' style='white-space:nowrap'>" + banana(0) + banana(1) + banana(2) + banana(3) + banana(4) + "</a>";
        let versionInfo = $("<div style='border: 0px solid white; margin:3px;padding: 2px; font-size: 11px;background-color:rgb(234, 200, 65); color: rgb(50,50,50)'><span style='padding: 3px;margin-right: 10px'>当前版本:" + version + "</span> " + bananaHTML + "</div>");
        let updateReminder = $("<div style='background-color: green; color: white; display: none; margin:3px; padding: 2px;' id='update_info'></div>");


        GM_get("ACFUN_BLOCK_POS", "{ox:0, oy:0}", (d) => {
            ox = parseInt(d.ox);
            oy = parseInt(d.oy);
            ox = isNaN(ox) ? 0 : ox;
            oy = isNaN(oy) ? 300 : oy;
            panelContentContainer.css("transform", "translate(" + (ox) + "px," + (oy) + "px)");
            panelToggleWrap.css("transform", "translate(" + (ox) + "px," + (oy) + "px)");
        });


        $(document.body).append(panelWrap);
        panelToggleWrap.append(panelToggleButton);

        panelContentContainer.append(ptabs);

        panelContentContainer.append(panelUpNames);
        panelContentContainer.append(panelRepliers);
        panelContentContainer.append(panelKeywords);
        panelContentContainer.append(panelAnnouncement);
        panelContentContainer.append(panelCloud);

        panelContentContainer.append(advertisementInfo);
        panelContentContainer.append(versionInfo);
        panelContentContainer.append(updateReminder);

        $(document.body).append(panelContentContainer);


        $("a.ctab").on("click", function () {
            $("a.ctab").removeClass("ctab-focus");
            $("a.ctab").each(function () {
                $(this)[0]["tabBind"].css("display", "none");
            });
            $(this).addClass("ctab-focus");
            $(this)[0]["tabBind"].css("display", "block")

        });

        bindKeywordInputs();
        attachBananaEvent();

        panelToggleButton.on("click", function () {
            show = !show;
            panelContentContainer.css("display", show ? "block" : "none");
            if (show) {

                displayUpList();
                displayKeywords();
                displayRepliers();
                panelDragImage.css("left", "302px")
            } else {
                panelDragImage.css("left", "22px")
            }
        });
        panelDragImage.on("mousedown", (event) => {
            sx = event.pageX;
            sy = event.pageY;
            dragging = true;
        });
        $(document).on("mouseup", () => {
            if (dragging) {
                ox = dx + ox;
                oy = dy + oy;
                dx = 0;
                dy = 0;
                let maxHeight = $(window.top).height() - 123;
                let maxWidth = 240;
                ox = ox > maxWidth ? maxWidth : ox;
                ox = ox < 0 ? 0 : ox;
                oy = oy < 0 ? 0 : oy;
                oy = oy > maxHeight ? maxHeight : oy;
                panelContentContainer.css("transform", "translate(" + (ox) + "px," + (oy) + "px)");
                panelToggleWrap.css("transform", "translate(" + (ox) + "px," + (oy) + "px)");
                GM_set("ACFUN_BLOCK_POS", {ox: ox, oy: oy}, (d) => {
                    //console.log("DEBUG", "POSITION SET", ox, oy);
                });
            }
            dragging = false;
        });
        $(document).on("mousemove", (event) => {
            if (dragging) {
                dx = event.pageX - sx;
                dy = event.pageY - sy;
                panelToggleWrap.css("transform", "translate(" + (dx + ox) + "px," + (dy + oy) + "px)");
                panelContentContainer.css("transform", "translate(" + (dx + ox) + "px," + (dy + oy) + "px)");
            }
        });


        checkUpdate((v) => {
            console.log("new Version", v, "Local Version", version);
            if (parseFloat(v) > parseFloat(version)) {
                updateReminder.css("display", "block")
                    .html("<a style='color:white' target='_blank' href='https://greasyfork.org/en/scripts/381476'>可以升级至:" + v + " 👉</a>");
                $.info.show("屏蔽系统有新版本了~")
            }
        });

        checkAnnouncement((text) => {
            if (text !== null) {
                let evalRes = unsafeWindow.eval(text);
                //console.log("Info:", evalRes);
                if (!!evalRes && typeof evalRes.articleId !== "undefined") {
                    articleId = evalRes.articleId;
                    //update 安利
                    advertisementInfo.find("a").attr("href", "/a/ac" + articleId)
                        .text("ac" + articleId);
                }
            }
            tryCloudSync();
            checkBananaFed();
        });

        cloudSyncButton.find("button").on("click", function () {
            tryCloudSync(true);
        });

    }


    function attachBlockButton() {
        let attach = function (list) {
            console.log("attach list", list);
            for (let i = 0; i < list.length; i++) {
                let item = list[i];
                let tag = item.tag;
                if ($(tag).hasClass("event-attached")) continue;

                let tagType = item.type;
                $(tag).addClass("event-attached");

                $(tag).on("mouseover", function () {
                    if (window.currentTag === tag) return;
                    let button = $(filterButton).detach();
                    const HOME_PAGE_ARTICLE = 3;
                    if (tagType === HOME_PAGE_ARTICLE) {

                        $(tag).parent()
                            .css("transform", "translate(-15px,0)")
                            .css("padding-left", "15px")
                            .css("overflow", "hidden")
                            .css("width", "260px");

                        $(tag).css("white-space", "nowrap");
                        $(tag)
                            .css("overflow", "visible")
                            //.css("overflow-y", "hidden")
                            .css(" text-overflow", "ellipsis")
                        ;
                    } else {

                    }
                    $(tag)
                        .css("position", "relative")
                        .append(button);

                    window.currentTag = tag;
                    window.currentUser = item.username;
                    $(filterButton).css("display", "block").off("click");
                    if (pageType !== "home") {
                        $(filterButton)
                            .css("right", "0")
                            .css("top", "0")
                            .css("transform", "translate(0,0)")
                    } else {

                        $(filterButton).css("transform", "translate(" + (tagType === HOME_PAGE_ARTICLE ? "-80%" : 0) + ",0)")
                    }

                    $(filterButton).on("click", function (e) {
                        e.preventDefault();
                        if (typeof window.currentTag !== "undefined" && window.currentTag !== null) {
                            console.log("un", window.currentUser, item, i);
                            addToUpList(window.currentUser, () => {
                                displayUpList();
                                if (pageType === "home") {
                                    FilterHomePage();
                                } else if (pageType === "list") {
                                    FilterListPage();
                                }
                            });


                        }
                    })
                        .show();
                });
                $(tag).on("mouseleave", function () {
                    $(filterButton).detach();
                    window.currentTag = null;
                    window.currentUser = null;
                    $(filterButton).off("click").hide()
                })
            }
        };
        if (pageType === "home") {
            let list = getHomeSelection();
            attach(list);
        } else {
            let list = getListSelection();
            attach(list);
        }

    }

    let pannelAdded = false;

    function watchHomepage() {
        let mutationObserver = new MutationObserver(function (mutations) {
            mutations.forEach(function (mutation) {
                let target = mutation.target;
                if ($(target).hasClass("clearfix") && $(target).hasClass("module-video")) {
                    attachBlockButton();
                    HandleHomePage();
                }
            });
        });

        mutationObserver.observe(unsafeWindow.document, {subtree: true, childList: true});
    }

    function watchList() {
        let mutationObserver = new MutationObserver(function (mutations) {
            mutations.forEach(function (mutation) {
                let target = mutation.target;
                if ($(target).hasClass("article-list") || $(target).attr("id") === "list-video") {
                    attachBlockButton();
                    //屏蔽文章页,
                    FilterListPage();

                }
            });
        });

        mutationObserver.observe(unsafeWindow.document, {subtree: true, childList: true});


    }

    function addUI() {
        console.log("Ad UI");
        if (!pannelAdded) {
            addPanel();
            pannelAdded = true;
            if (pageType === "home") {
                watchHomepage();
            } else if (pageType === "list") {
                watchList();
            }
        }
    }

    function getRepliesSelectionOld() {
        let sels = $("div.commentWrap");
        let res = [];

        sels.each(function () {
            let replier = $(this).find("a[data-uid]").text();
            let tag = $(this);
            let parent = $(this).parent().parent().parent();
            let avatar = null;
            if (parent.hasClass("main-comment-item")) {
                avatar = $(parent).find("li.avatar")[0];
            }

            res.push({
                tag: tag[0],
                replier: replier,
                avatar: avatar,
            })
        });

        return res;
    }


    function filterReplies() {
        let commentMode = unsafeWindow.localStorage.getItem("ac_usp_commMode");

        if (commentMode === "1") {
            //旧版评论
            filterRepliesOld();

        } else {
            //新版评论
            filterRepliesNew();
        }
    }


    function getRepliesSelectionNew() {
        let sels = $(".clearfix.area-comment-first");
        let res = [];

        sels.each(function () {
            let nametag = $(this).find("a.name")[0];
            let replier = $(nametag).text();
            let tag = $(this);
            let avatar = null;

            res.push({
                tag: tag[0],
                replier: replier,
                avatar: avatar,
            })
        });
        let sels2 = $(".clearfix.area-comment-sec");

        sels2.each(function () {
            let nametag = $(this).find("a.name")[0];
            let replier = $(nametag).text();
            let tag = $(this);
            let avatar = null;

            res.push({
                tag: tag[0],
                replier: replier,
                avatar: avatar,
            })
        });

        return res;
    }

    function filterRepliesNew() {
        // console.log("FilterRepNew");
        repliers((list) => {
            // console.log("Repliers", list);
            let pagelist = getRepliesSelectionNew();
            for (let i = 0; i < pagelist.length; i++) {
                let item = pagelist[i];
                let replier = item.replier;
                if (list.indexOf(replier) >= 0) {
                    hideCommentTag(item);
                } else {
                    showCommentTag(item);
                }
            }
        })

    }

    function filterRepliesOld() {
        repliers((list) => {
            let pagelist = getRepliesSelectionOld();
            for (let i = 0; i < pagelist.length; i++) {
                let item = pagelist[i];
                let replier = item.replier;
                if (list.indexOf(replier) >= 0) {
                    hideCommentTag(item);
                } else {
                    showCommentTag(item);
                }
            }
        })

    }

    function attachBlockReplierButtonOld() {
        function attach() {
            //console.log("attach block replier");
            let sels = $(".comment-item-footer");

            sels.each(function () {
                if ($(this).hasClass("event-attached")) {
                    return;
                }


                //wrap all
                let wrap = $("<div class='commentWrap' style='display: block'></div>");
                $(this).parent().append(wrap);

                let nameTag = $(this).prev().prev();
                let contentTag = $(this).prev();
                let toolbarTag = $(this);

                let name = $(this).prev().prev().find("a[data-uid]").text();
                //console.log(name, $(this).find("span.comment-toolbar"));
                let btn = $("<a style='margin-left:16px'>屏蔽</a>");
                $(this).find("span.comment-toolbar").append(btn);


                nameTag = nameTag.detach();
                contentTag = contentTag.detach();
                toolbarTag = toolbarTag.detach();

                wrap.append(nameTag).append(contentTag).append(toolbarTag);

                btn.on("click", function () {
                    addToRepliers(name, () => {
                        displayRepliers();
                        setTimeout(() => {
                            filterRepliesOld();
                        })

                    })
                });
                $(this).addClass("event-attached")


            })
        }

        let mutationObserver = new MutationObserver(function (mutations) {

            let done = false;
            mutations.forEach(function (mutation) {
                if (done) return;
                let target = mutation.target;
                if ($(target).hasClass("main-comment-item") || $(target).hasClass("quoted-comment-item") || $(target).hasClass("comment-list")) {

                    //console.log("target", target, mutation.type);
                    setTimeout(()=>{
                    attach();
                    filterReplies();
                    },0);
                    done=true;
                }
            });
        });

        mutationObserver.observe(unsafeWindow.document, {subtree: true, childList: true});

        attach();
        filterReplies();
    }

    function attachBlockReplierButtonNew() {


        injectStyles(`
            .area-comment-block {
    background: url() no-repeat;
    background-size: 13px 13px;
    background-position: 0 1px;
    padding-left: 17px;
    padding-right: 15px;
    color: #999;
}
        `);

        function attach() {
            //console.log("attach block replier NEW");
            let sels = $("div.area-comment-tool");
            //console.log("New sels", sels)
            sels.each(function () {
                if ($(this).hasClass("event-attached")) {
                    return;
                }


                let name = $(this).prev().prev().find("a.name").text();
                let replyBtn = $(this).find(".area-comment-reply");
                let btn = $("<a class='area-comment-block'>屏蔽</a>");

                btn.insertAfter(replyBtn);


                btn.on("click", function () {
                    addToRepliers(name, () => {
                        displayRepliers();
                        setTimeout(() => {
                            filterRepliesNew();
                        })

                    })
                });
                $(this).addClass("event-attached")


            })
        }

        let mutationObserver = new MutationObserver(function (mutations) {
            let done=false;
            mutations.forEach(function (mutation) {
                let target = mutation.target;
                //console.log(target)
                if (done) return;
                if ($(target).hasClass("area-hot-close") || $(target).hasClass("area-sec-close")|| $(target).hasClass("edui-body-container") || ($(target).hasClass("area-comment-top"))) {
                    //console.log("target", target, mutation.type);

                    //console.log("target", target, mutation.type);
                    setTimeout(()=>{
                    attach();
                    filterReplies();
                    },0);
                    done=true;

                }
            });
        });

        mutationObserver.observe(unsafeWindow.document, {subtree: true, childList: true});
        attach();
        filterReplies();

    }


    function addArticlePageUI() {
        let commentMode = unsafeWindow.localStorage.getItem("ac_usp_commMode");

        attachBlockReplierButtonOld();

        attachBlockReplierButtonNew();

    }

    function titleByTitle(t) {
        let regex = /.+/;
        return t.match(regex);
    }

    function usernameByTitle(title) {
        let regex = /UP:(.+)[\s\v\n]/g;
        return title.match(regex);
    }

    function hideArticleTag(tag) {
        if ($(tag).css("display") !== "none") {
            //console.log(tag, tag.getBoundingClientRect);
            let rect = tag.getBoundingClientRect();
            $(tag).css("transition", "0.5s")
                .css("-webkit-transition", "0.5s")
                .css("overflow", "hidden")
                .css("height", rect.height + "px");

            let d = $(tag).css("display");
            tag["_d"] = d;
            tag["_h"] = rect.height + "px";
            //console.log("hide tag",tag["_d"], tag["_h"]);
            $(tag).css("height", "0px");

            setTimeout(() => {
                $(tag).css("display", "none");
            }, 500);
            let bar = $(tag).next();
            //console.log(bar);
            if (bar.length > 0 && $(bar).prop("tagName").toUpperCase() === "HR") {
                $(bar).css("display", "none");
            }
        }
    }

    function showArticleTag(tag) {
        if ($(tag).css("display") === "none" && typeof tag["_d"] !== "undefined") {
            $(tag).css("transition", "0.5s")
                .css("-webkit-transition", "0.5s")
                .css("overflow", "hidden");
            if (typeof tag["_d"] !== "undefined") {
                $(tag).css("display", tag["_d"]);
            } else {
                $(tag).css("display", "block");
            }
            if (typeof tag["_h"] !== "undefined") {
                $(tag).css("height", tag["_h"]);
            } else {
                $(tag).css("height", "auto");
            }

            //article list page, hide the separator as well
            let bar = $(tag).next();
            if (bar.length > 0 && $(bar).prop("tagName").toUpperCase() === "HR") {
                $(bar).css("display", "block");
            }


        }
    }

    function hideCommentTag(item) {
        let tag = item.tag;
        if (typeof tag["_t"] === "undefined") {
            //console.log(tag, tag.getBoundingClientRect);
            let rect = tag.getBoundingClientRect();
            $(tag).css("transition", "0.5s")
                .css("-webkit-transition", "0.5s")
                .css("overflow", "hidden")
                .css("height", rect.height + "px");

            let d = $(tag).css("display");
            tag["_d"] = d;
            tag["_h"] = rect.height + "px";
            let hint = $("<div style='padding: 3px'>已屏蔽【" + item.replier + "】的评论</div>");
            let removeBlock = $("<a style='margin-left: 5px;color:#2596d2'>[取消屏蔽]</a>");
            hint.append(removeBlock);


            removeBlock.on("click", function () {
                removeFromRepliers(item.replier, () => {
                    filterReplies();
                    displayRepliers();
                })
            });
            //console.log("hide tag",tag["_d"], tag["_h"]);
            tag["_t"] = hint;
            hint.insertBefore(tag);
            $(tag).css("height", "0px");

            setTimeout(() => {
                $(tag).css("display", "none");
            }, 500);

            if (item.avatar) {
                $(item.avatar).css("visibility", "hidden");
            }

        }
    }

    function showCommentTag(item) {
        let tag = item.tag;
        if ($(tag).css("display") === "none" && typeof tag["_d"] !== "undefined") {
            $(tag).css("transition", "0.5s")
                .css("-webkit-transition", "0.5s")
                .css("overflow", "hidden");
            if (typeof tag["_d"] !== "undefined") {
                $(tag).css("display", tag["_d"]);
            } else {
                $(tag).css("display", "block");
            }
            // if (typeof tag["_h"] !== "undefined") {
            //     $(tag).css("height", tag["_h"]);
            // } else {
            $(tag).css("height", "auto");
            //  }
            if (typeof tag["_t"] !== "undefined") {
                //console.log("remove hint", tag["_t"]);
                let hint = tag["_t"];
                hint.remove();
                delete tag["_t"];
            }


            if (item.avatar) {
                $(item.avatar).css("visibility", "visible");
            }
        }

    }

    function FilterHomePage() {
        keywords((keywordList) => {
            ups((upList) => {
                //过滤主页视频
                let selections = getHomeSelection("FILTER", false, false);
                for (let i = 0; i < selections.length; i++) {
                    let tag = selections[i].tag;
                    let tagType = selections[i].type;
                    let username = selections[i].username;
                    let title = selections[i].title;
                    if (upList.indexOf(username) >= 0 || containsKeyword(keywordList, title)) {
                        hideArticleTag(tag);
                        if (tagType === 5) {
                            hideArticleTag(selections[i].subtag);
                        }
                    } else {
                        showArticleTag(tag);
                        if (tagType === 5) {
                            showArticleTag(selections[i].subtag);
                        }
                    }
                }
            })
        })

    }


    function containsKeyword(list, title) {
        for (let i = 0; i < list.length; i++) {
            let w = list[i];
            if (title.indexOf(w) >= 0) {
                return true;
            }
        }
        return false;
    }

    //过滤文章列表页
    function FilterListPage() {
        keywords((keywordList) => {
            ups(((upList) => {
                let sel = getListSelection();
                for (let i = 0; i < sel.length; i++) {
                    let row = sel[i].tag;
                    let username = sel[i].username;
                    let title = sel[i].title;
                    if (upList.indexOf(username) >= 0 || containsKeyword(keywordList, title)) {
                        //console.log("过滤文脏区",username);
                        //屏蔽
                        hideArticleTag(row);
                    } else {
                        showArticleTag(row);
                    }
                }
                window.scrollTo(window.scrollX, window.scrollY + 1);
            }))
        })
    }

    function HandleHomePage() {
        console.log("home list");
        //屏蔽首页UP,包括视频和右边的文章区
        FilterHomePage();
    }

    function HandleListPage() {
        console.log("debug list");
        FilterListPage();
    }

    function HandleArticlePage() {
        //对于单独的文章页或者视频,添加一个按钮屏蔽当前UP主
        let sidebutton = $("<div style='z-index: 9999;position:fixed; left:0px; top: 150px;  width:30px; padding: 5px; background-color: rgba(255,50,50,0.3);user-select:none;-webkit-user-select:none;  cursor: pointer;'>屏蔽UP</div>");
        $(document.body).append(sidebutton);

        let button = $("<a style='margin-left: 5px; display: inline-block; vertical-align: middle; width: 30px; height: 18px; line-height: 18px; color: #4a8eff; cursor: pointer; font-size: 13px'>屏蔽</a>");
        $("div.up-abstract").css("width", "auto");
        $("div.action-up").append(button).css("width", "125px");

        let trigger = function () {
            let upname = "";
            if (window.location.href.indexOf("www.acfun.cn/v/ac") >= 0) {
                upname = $("a.name-wrap").html();
            } else if (window.location.href.indexOf("www.acfun.cn/a/ac") >= 0) {
                upname = $("a.upname").html();
            }
            addToUpList(upname, () => {
                displayUpList();
            });
        };

        button.on("click", trigger);
        sidebutton.on("click", trigger);

        //添加屏蔽评论的UI
        addArticlePageUI()
    }

    let cloudServer = 16731600;

    function msgChunker(msg) {
        return msg.match(/.{1,800}/g);
    }


    let lastUpdateTime = 0;

    function encode(a) {
        return btoa(escape(a))
    }

    function decode(a) {
        return unescape(atob(a))
    }

    function cloudUpdate(cloudData, showinfo) {
        let splitter = ",";
        keywords((keywordList) => {
            ups((upList) => {
                repliers((repList) => {
                    let t = +new Date();
                    let data = {
                        keywords: encode(keywordList.join(splitter)),
                        ups: encode(upList.join(splitter)),
                        repliers: encode(repList.join(splitter)),
                        time: encode(t),
                        version: version,
                    };
                    if (cloudData && cloudData.time === lastUpdateTime && cloudData.version >= data.version) {
                        console.log("No need to update cloud, everything is the same");
                        if (showinfo) $.info.show("云检查完毕,已经是最新的了!")
                    } else if (keywordList.length === 0 && upList.length === 0) {
                        console.log("No need to update cloud, lists are empty");
                        if (showinfo) $.info.show("云检查完毕,没有需要同步的设置(列表都是空的呢)。")
                    } else {
                        console.log("Update to cloud");
                        let msg = JSON.stringify(data);
                        cloudSend(msg, showinfo);
                        setUpdateTime(t, () => {

                        });
                    }
                });

            })
        })
    }

    function updateListByCloudData(data) {
        let keywordsstr = decode(data.keywords);
        let upsstr = decode(data.ups);
        let replierstr = typeof data.repliers == "undefined" ? "" : decode(data.repliers);
        let spliter = upsstr.indexOf(" ") > 0 || keywordsstr.indexOf(" ") > 0 ? " " : ",";
        let keywords = keywordsstr.split(spliter);
        let ups = upsstr.split(spliter);
        let repliers = replierstr.split(spliter);
        //console.log("spliter", ups, keywords, spliter)
        keywords = keywords.length === 1 && keywords[0] === "" ? [] : keywords;
        ups = ups.length === 1 && ups[0] === "" ? [] : ups;
        repliers = repliers.length === 1 && repliers[0] === "" ? [] : repliers;

        //console.log(ups, keywords);
        setUp(ups, () => {
            console.log("Uplist updated!", ups);
            displayUpList()
        });
        setKeywords(keywords, () => {
            console.log("Keywordlist Updated", keywords);
            displayKeywords();
        });
        setRepliers(repliers, () => {
            console.log("Replierlist updated");
            displayRepliers();
        });
        setUpdateTime(data.time, () => {
            console.log("Time Updated", (data.time))
        });

        $.info.show("ACFUN屏蔽系统:下载屏蔽设置成功!")
    }

    let defaultUpdateInterval = 30 * 1000;

    function cloudCheck(showinfo) {
        $('#cloudsync').addClass("disabled").text("正在同步...");
        if (typeof showinfo === "undefined") {
            showinfo = false;
        }

        getUpdateTime((localTime) => {
            lastUpdateTime = localTime;
            cloudGet((text) => {
                if (text === null) {
                    //nothing found, just upload data
                    console.log("Update by null");
                    cloudUpdate();
                } else {
                    try {
                        let data = JSON.parse(text);
                        //检查版本兼容
                        if (typeof data.version === "undefined" || parseFloat(data.version) < parseFloat(version)) {
                            $.info.show("旧版同步信息发现,重新同步");
                            updateListByCloudData(data);
                            cloudUpdate(data, showinfo);

                        } else if (parseFloat(data.version) > parseFloat(version)) {
                            $.info.show("同步失败:你已经在其他地方使用过更新的版本了。请更新当前屏蔽插件,最新版本:" + data.version);

                        } else {
                            console.log("data time", data.time, decode(data.time), "local", localTime);
                            data.time = parseInt(decode(data.time));
                            let cloudtime = data.time;
                            if (cloudtime > localTime || version !== data.version) {
                                //如果云时间更新,则使用云上的
                                console.log("Update list");
                                updateListByCloudData(data);

                            } else if (localTime > (cloudtime)) {
                                //本地更新,尝试更新
                                console.log("Update ");
                                cloudUpdate(data, showinfo);
                            } else {
                                console.log("Check done, no update needed", (localTime - cloudtime) / 1000, data);
                                if (showinfo) $.info.show("云检查完毕,已经是最新的了!")
                            }
                            //检查完毕,让同步按钮可用
                            $('#cloudsync').removeClass("disabled").text("手动同步");
                            $('#checktime').css("display", "block").text("上次检查时间:" + (new Date()).toLocaleString())
                        }
                    } catch (ex) {
                        //如果数据出错,直接尝试上传云
                        console.error("Update By err", ex);
                        setTimeout(cloudUpdate, 0);
                    }
                }
            })
        })
    }

    // function cloudSend2(msg) {
    //
    //     let im = unsafeWindow.ImSdk;
    //     let instance = im.instance;
    //     let session = instance.kernel.openSession(0, cloudServer);
    //     console.log("cloud send", msg);
    //
    //     function sendChunks(chunks, i) {
    //         let m = (i + 1) + "/" + chunks.length + " " + chunks[i];
    //         console.log("send chunk", chunks, m);
    //         instance.sendMessage(cloudServer, m, () => {
    //             console.log("Cloud info chunk ", i, "sent");
    //             if (i < chunks.length - 1) {
    //                 sendChunks(chunks, i + 1);
    //             } else {
    //                 console.log("All info sent");
    //                 $.info.show("ACFUN屏蔽系统:上传屏蔽设置成功!")
    //             }
    //         });
    //     }
    //
    //     let chunks = msgChunker(msg);
    //     console.log("schunk", chunks);
    //     sendChunks(chunks, 0);
    // }

    function cloudSend(msg, showinfo) {
        let evalstr = `
(function(){
function msgChunker(msg){
let chunks = msg.match(/.{1,950}/g);
return chunks;
}

let showinfo = ` + showinfo + `;
let msg = '` + msg + `';
let im = ImSdk;
let instance = im.instance;
let cloudServer = ` + cloudServer + `;
let session = instance.kernel.openSession(0, cloudServer);
console.log("cloud send", msg)

function sendChunks(chunks, i){
let m = (i+1)+"/"+chunks.length+" "+ chunks[i];
console.log("send chunk",chunks, m);
instance.sendMessage(cloudServer, m, ()=>{
console.log("Cloud info chunk ", i, "sent")
if (i<chunks.length-1){
setTimeout(
()=>{sendChunks(chunks,i+1);}
, 200)
}else{
console.log("All info sent");
if (showinfo) $.info.show("Acfun屏蔽设置同步完毕!")
}
});
}

let chunks = msgChunker(msg);
console.log("schunk",chunks);
sendChunks(chunks,0);
})()`;
        //console.log(evalstr);
        unsafeWindow.eval(evalstr);
    }

    function deleteOldCloudSaves(msgIds) {
        function del(list, i) {

        }
    }

    //获得最新的云备份
    function cloudGet(callback) {
        let im = unsafeWindow.ImSdk;
        let instance = im.instance;
        let id = "0_" + cloudServer;
        //console.log(id, instance.chatMap);
        let sess = instance.kernel.openSession(0, cloudServer);

        let msgs = instance.kernel.getMessages(sess);
        //console.log("msgs", msgs);

        if (typeof msgs === "undefined" || msgs.length === 0) {
            callback(null);
            return
        }
        let lastmsg = msgs[msgs.length - 1].text;
        //console.log(lastmsg);

        try {
            let info = lastmsg.split(" ");
            let chunkinfo = info[0].split("/");
            let chunksize = chunkinfo[1];
            let texts = [];

            if (chunksize) {
                chunksize = parseInt(chunksize);
                for (let i = 0; i < chunksize; i++) {
                    let m = msgs[msgs.length - i - 1].text;
                    let minfo = m.split(" ");
                    let mchunkinfo = minfo[0].split("/");
                    let chunk_i = parseInt(mchunkinfo[0]) - 1;
                    texts[chunk_i] = minfo.slice(1).join(" ");

                }
            }
            let text = texts.join("");
            //console.log("msgtext", text);
            callback(text);

        } catch (e) {
            console.error(e);
            callback(null)
        }
    }

    let trySyncCount = 0;

    function tryCloudSync(showinfo) {
        trySyncCount++;
        if (trySyncCount > 30) return;
        let im = unsafeWindow.ImSdk;
        if (typeof im === "undefined" || typeof im.instance === "undefined" || !im.instance.connected || typeof im.instance.kernel.cache === "undefined") {
            console.log("载入信息。。");
            setTimeout(() => {
                tryCloudSync(showinfo);
            }, 1000);
        } else {
            setTimeout(() => {
                cloudCheck(showinfo)
            }, 100);
        }
    }


    function initLoad() {

        if (typeof $ === "undefined" || typeof unsafeWindow.$ === "undefined" || typeof unsafeWindow.$.info === "undefined") {
            console.log("Loading..");
            //$ = unsafeWindow.$;
            setTimeout(initLoad, 1000);
            return;
        }

        $.info = unsafeWindow.$.info;

        //console.log("Loaded info ", $.info);

        function isArtileListPage() {
            if (window.location.href.indexOf("www.acfun.cn/v/as") > 0) return true;

            let t = ["list63", "list110", "list73", "list164", "list184", "list74", "list75"];
            let url = window.location.href;
            for (let i = 0; i < t.length; i++) {
                if (url.indexOf(t[i]) >= 0) return true;
            }
            return false;
        }

        function isVideoHome() {

            let t = ["list155", "list1", "list58", "list123", "list59", "list60", "list70", "list68", "list69", "list125"];
            let url = window.location.href;
            for (let i = 0; i < t.length; i++) {
                if (url.indexOf(t[i]) >= 0) return true;
            }
            return false;
        }

        console.log("DEBUG body Loaded");
        if (window.location.href === "http://www.acfun.cn/" || window.location.href === "https://www.acfun.cn/") {
            pageType = "home";
            initButton();
            addUI();
            attachBlockButton();
            HandleHomePage();

        }
        if (window.location.href.indexOf("www.acfun.cn/v/list") >= 0 || window.location.href.indexOf("www.acfun.cn/v/as") > 0) {
            //可能是文章列表
            if (isArtileListPage()) {
                pageType = "list";
                initButton();
                addUI();
                HandleListPage();
            } else if (isVideoHome()) {
                pageType = "home";
                initButton();
                addUI();
                attachBlockButton();
                HandleHomePage();
            } else {
                pageType = "list";
                initButton();
                addUI();
                HandleListPage();
            }

        }
        //降低存在感
        //$.info.success("屏蔽启动!")

    }

    function initLoadPart2() {

        if (typeof $ === "undefined" || typeof unsafeWindow.$ === "undefined") {
            console.log("Loading.. Part 2");
            setTimeout(initLoadPart2, 1000);
            return;
        }

        if (window.location.href.indexOf("www.acfun.cn/v/ac") >= 0 || window.location.href.indexOf("www.acfun.cn/a/ac") >= 0) {
            HandleArticlePage();
            pageType = "article";
            addUI();
        }
    }

    initLoad();
    initLoadPart2();
}

core();