Greasy Fork is available in English.

全球主机交流论坛增强

自动签到(访问空间 +22 积分)、屏蔽用户(黑名单)、屏蔽关键词(帖子标题)、回帖小尾巴、自动无缝翻页、快捷回到顶部(右键点击两侧空白处)、收起预览帖子(左键点击两侧空白处)、预览帖子快速回复带签名、显示是否在线、显示帖子内隐藏回复、屏蔽阅读权限 255 帖子

Από την 04/08/2021. Δείτε την τελευταία έκδοση.

// ==UserScript==
// @name         全球主机交流论坛增强
// @version      1.3.4
// @author       X.I.U
// @description  自动签到(访问空间 +22 积分)、屏蔽用户(黑名单)、屏蔽关键词(帖子标题)、回帖小尾巴、自动无缝翻页、快捷回到顶部(右键点击两侧空白处)、收起预览帖子(左键点击两侧空白处)、预览帖子快速回复带签名、显示是否在线、显示帖子内隐藏回复、屏蔽阅读权限 255 帖子
// @match        *://hostloc.com/*
// @match        *://91ai.net/*
// @icon         https://www.hostloc.com/favicon.ico
// @grant        GM_xmlhttpRequest
// @grant        GM_registerMenuCommand
// @grant        GM_unregisterMenuCommand
// @grant        GM_openInTab
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_notification
// @license      GPL-3.0 License
// @run-at       document-end
// @namespace    https://greasyfork.org/scripts/414005
// @supportURL   https://github.com/XIU2/UserScript
// @homepageURL  https://github.com/XIU2/UserScript
// ==/UserScript==

(function() {
    'use strict';
    var menu_ALL = [
        ['menu_autoSignIn', '自动签到(22 积分)', '自动签到', true],
        ['menu_reAutoSignIn', '重新签到', '重新签到', ''],
        ['menu_blockUsers', '屏蔽用户', '屏蔽用户', false],
        ['menu_customBlockUsers', '自定义屏蔽用户', '自定义屏蔽用户', []],
        ['menu_blockKeywords', '屏蔽关键词(帖子标题)', '屏蔽关键词(帖子标题)', false],
        ['menu_customBlockKeywords', '自定义屏蔽关键词', '自定义屏蔽关键词', []],
        ['menu_customLittleTail', '自定义小尾巴内容', '自定义小尾巴内容', []],
        ['menu_pageLoading', '自动无缝翻页(总开关)', '自动无缝翻页', true],
        ['menu_thread_pageLoading', '帖子内自动翻页', '帖子内自动翻页', true],
        ['menu_backToTop', '快捷回到顶部(右键点击两侧空白处)', '快捷回到顶部', true],
        ['menu_collapsedNowPost', '收起预览帖子(左键点击两侧空白处)', '收起预览帖子', true],
        ['menu_onlineStatus', '显示是否在线', '显示是否在线', true],
        ['menu_showhide', '显示帖子内隐藏回复', '显示帖子内隐藏回复', true],
        ['menu_delate255', '屏蔽阅读权限 255 帖子', '屏蔽阅读权限 255 帖子', true]
    ], menu_ID = [];
    for (let i=0;i<menu_ALL.length;i++){ // 如果读取到的值为 null 就写入默认值
        if (GM_getValue(menu_ALL[i][0]) == null){GM_setValue(menu_ALL[i][0], menu_ALL[i][3])};
    }
    registerMenuCommand();

    // 注册脚本菜单
    function registerMenuCommand() {
        if (menu_ID.length > menu_ALL.length){ // 如果菜单ID数组多于菜单数组,说明不是首次添加菜单,需要卸载所有脚本菜单
            for (let i=0;i<menu_ID.length;i++){
                GM_unregisterMenuCommand(menu_ID[i]);
            }
        }
        for (let i=0;i<menu_ALL.length;i++){ // 循环注册脚本菜单
            menu_ALL[i][3] = GM_getValue(menu_ALL[i][0]);
            if (menu_ALL[i][0] === 'menu_reAutoSignIn') {
                menu_ID[i] = GM_registerMenuCommand(`#️⃣ ${menu_ALL[i][1]}`, function(){reAutoSignIn()});
            } else if (menu_ALL[i][0] === 'menu_customBlockUsers') {
                menu_ID[i] = GM_registerMenuCommand(`#️⃣ ${menu_ALL[i][1]}`, function(){customBlockUsers()});
            } else if (menu_ALL[i][0] === 'menu_customBlockKeywords') {
                menu_ID[i] = GM_registerMenuCommand(`#️⃣ ${menu_ALL[i][1]}`, function(){customBlockKeywords()});
            } else if (menu_ALL[i][0] === 'menu_customLittleTail') {
                menu_ID[i] = GM_registerMenuCommand(`#️⃣ ${menu_ALL[i][1]}`, function(){customLittleTail()});
            } else {
                menu_ID[i] = GM_registerMenuCommand(`${menu_ALL[i][3]?'✅':'❎'} ${menu_ALL[i][1]}`, function(){menu_switch(`${menu_ALL[i][3]}`,`${menu_ALL[i][0]}`,`${menu_ALL[i][2]}`)});
            }
        }
        menu_ID[menu_ID.length] = GM_registerMenuCommand('💬 反馈 & 建议', function () {window.GM_openInTab('https://github.com/XIU2/UserScript#xiu2userscript', {active: true,insert: true,setParent: true});window.GM_openInTab('https://greasyfork.org/zh-CN/scripts/414005/feedback', {active: true,insert: true,setParent: true});});
    }

    // 菜单开关
    function menu_switch(menu_status, Name, Tips) {
        if (menu_status == 'true'){
            GM_setValue(`${Name}`, false);
            GM_notification({text: `已关闭 [${Tips}] 功能\n(刷新网页后生效)`, timeout: 3500});
        }else{
            GM_setValue(`${Name}`, true);
            GM_notification({text: `已开启 [${Tips}] 功能\n(刷新网页后生效)`, timeout: 3500});
        }
        registerMenuCommand(); // 重新注册脚本菜单
    };

    // 返回菜单值
    function menu_value(menuName) {
        for (let menu of menu_ALL) {
            if (menu[0] == menuName) {
                return menu[3]
            }
        }
    }

    // 检查是否登陆
    var loginStatus = false;
    if (document.getElementById('um')){
        loginStatus = true;
    } else {
        loginStatus = getLoginStatus();
    }

    // 默认 ID 为 0
    var curSite = {SiteTypeID: 0};

    // 自动翻页规则
    let DBSite = {
        forum: {
            SiteTypeID: 1
        },
        thread: {
            SiteTypeID: 2,
            pager: {
                nextLink: '//a[@class="nxt"][@href]',
                pageElement: 'css;div#postlist > div[id^="post_"]',
                HT_insert: ['css;div#postlist', 2],
                replaceE: 'css;div.pg',
            }
        },
        search: {
            SiteTypeID: 3,
            pager: {
                nextLink: '//a[@class="nxt"][@href]',
                pageElement: 'css;div#threadlist > ul',
                HT_insert: ['css;div#threadlist', 2],
                replaceE: 'css;div.pg'
            }
        },
        guide: {
            SiteTypeID: 4,
            pager: {
                nextLink: '//a[@class="nxt"][@href]',
                pageElement: 'css;div#threadlist div.bm_c table > tbody',
                HT_insert: ['css;div#threadlist div.bm_c table', 2],
                replaceE: 'css;div.pg',
            }
        },
        youreply: {
            SiteTypeID: 5,
            pager: {
                nextLink: '//a[@class="nxt"][@href]',
                pageElement: 'css;tbody > tr:not(.th)',
                HT_insert: ['css;tbody', 2],
                replaceE: 'css;div.pg',
            }
        }
    };

    // 用于脚本内部判断当前 URL 类型
    let SiteType = {
        FORUM: DBSite.forum.SiteTypeID, // 各板块帖子列表
        THREAD: DBSite.thread.SiteTypeID, // 帖子内
        GUIDE: DBSite.guide.SiteTypeID, // 导读帖子列表
        SEARCH: DBSite.search.SiteTypeID // 搜索结果列表
    };

    // URL 匹配正则表达式
    let patt_thread = /\/thread-\d+-\d+\-\d+.html/,
        patt_forum = /\/forum-\d+-\d+\.html/

    // URL 判断
    if (patt_thread.test(location.pathname) || location.search.indexOf('mod=viewthread') > -1) { // 帖子内
        if (menu_value('menu_thread_pageLoading')) {
            curSite = DBSite.thread;
            hidePgbtn(); //                                               隐藏帖子内的 [下一页] 按钮
        }
        showPosts(); //                                                   自动显示帖子内被隐藏的回复
        blockUsers('thread'); //                                          屏蔽用户(黑名单)
        if (menu_value('menu_onlineStatus')) onlineStatus(); //           显示是否在线
        littleTail('thread'); //                                          小尾巴
    } else if (patt_forum.test(location.pathname) || location.search.indexOf('mod=forumdisplay') > -1) { // 各板块帖子列表
        curSite = DBSite.forum;
        if (menu_value('menu_collapsedNowPost')) collapsedNowPost(); //   收起当前帖子预览(左键左右两侧空白处)
        if (menu_value('menu_delate255')) delate255(); //                 自动隐藏阅读权限 255 的帖子
        blockUsers('forum'); //                                           屏蔽用户(黑名单)
        blockKeywords(); //                                               屏蔽关键词(帖子标题)
        vfastpostDOMNodeInserted(); //                                    监听插入事件(预览快速回复带签名)
        littleTail('forum'); //                                           小尾巴
        if (patt_forum.test(location.pathname)) blockDOMNodeInserted(); //监听插入事件(有新的回复主题,点击查看)
     }else if (location.search.indexOf('mod=guide') > -1) { //            导读帖子列表
        curSite = DBSite.guide;
    } else if(location.pathname === '/search.php') { //                   搜索结果列表
        curSite = DBSite.search;
        blockUsers('search'); //                                          屏蔽用户(黑名单)
    } else if(location.pathname === '/home.php' && location.search.indexOf('mod=space&do=notice&view=mypost') > -1) { // 消息(帖子/点评/提到)
        blockUsers('notice'); //                                          屏蔽用户(黑名单)
    } else if(location.pathname === '/home.php' && location.search.indexOf('mod=space&do=pm') > -1) { // 消息(私人聊天)
        blockUsers('pm'); //                                              屏蔽用户(黑名单)
    } else if(location.search.indexOf('mod=space') > -1 && location.search.indexOf('&view=me') > -1) { // 别人的主题/回复
        curSite = DBSite.youreply;
    } else if(location.pathname === '/forum.php' && location.search.indexOf('mod=post&action=reply') > -1 || location.pathname === '/forum.php' && location.search.indexOf('mod=post&action=newthread') > -1) { // 回复:高级回复
        littleTail('reply'); //                                           小尾巴
    }

    curSite.pageUrl = ""; // 下一页URL
    pageLoading(); // 自动翻页
    if(menu_value('menu_backToTop'))backToTop(); //    回到顶部(右键点击左右两侧空白处)
    if(menu_value('menu_autoSignIn'))autoSignIn(); //  自动签到(访问空间 10 次 = 20 积分)
    //replyIntervalDOMNodeInserted(); //                 监听插入事件(回帖间隔)


    // 自动签到(访问空间 10 次 = 20 积分 + 当天首次访问论坛 2 积分)
    function autoSignIn() {
        if (!loginStatus) return
        let timeNow = new Date().getFullYear() + "/" + (new Date().getMonth() + 1) + "/" + new Date().getDate(),
            timeOld = GM_getValue('menu_signInTime');
        if (!timeOld || timeOld != timeNow) { // 是新的一天
            GM_setValue('menu_signInTime', timeNow); //      写入签到时间以供后续比较
            GM_notification({text: '请不要关闭/刷新本页!耐心等待 60 秒~\n在此期间可以在 "其他标签页" 浏览论坛!', timeout: 10000});
            let url_list = [],
                url = 0;
            // 随机生成 12 个空间地址(2 个冗余)
            for(let i = 0;i < 12;i++){url_list[i] = "https://" + location.host + "/space-uid-" + Math.floor(Math.random()*(50000-10000+1)+10000) + ".html";}
            // 每 5 秒访问一次(避免触发网站防御机制,而且还可以适当浏览论坛)
            let signIn = setInterval(function(){
                GM_xmlhttpRequest({
                    url: url_list[url++],
                    method: "GET",
                    timeout: 4000
                });
                console.log(`[全球主机交流论坛 增强] 积分 +2 (${url_list[url]})`);
                if (url === 11) { // 次数够了就取消定时循环
                    clearInterval(signIn);
                    console.log('[全球主机交流论坛 增强] 签到完成!');
                    GM_notification({text: '签到完成!积分 +22 ~', timeout: 3500});
                }
            }, 5000);
        }
    }


    // 重新签到
    function reAutoSignIn() {
        GM_setValue('menu_signInTime', '1970/1/1'); // 设置为比当前日期更早
        location.reload(); // 刷新网页
    }


    // 自定义屏蔽用户
    function customBlockUsers() {
        let nowBlockUsers = '';
        GM_getValue('menu_customBlockUsers').forEach(function(item){nowBlockUsers += '|' + item})
        let newBlockUsers = prompt('编辑 [自定义屏蔽用户],刷新网页后生效\n(不同用户名之间使用 "|" 分隔,\n(例如:用户A|用户B|用户C,如果只有一个就不需要 "|" 了。', nowBlockUsers.replace('|',''));
        if (newBlockUsers === '') {
            GM_setValue('menu_customBlockUsers', []);
            registerMenuCommand(); // 重新注册脚本菜单
        } else if (newBlockUsers != null) {
            GM_setValue('menu_customBlockUsers', newBlockUsers.split('|'));
            registerMenuCommand(); // 重新注册脚本菜单
        }
    };


    // 屏蔽用户
    function blockUsers(type) {
        if (!menu_value('menu_blockUsers')) return
        if (!menu_value('menu_customBlockUsers') || menu_value('menu_customBlockUsers').length < 1) return
        switch(type) {
            case 'thread': // 帖子内
                blockUsers_('[id^="post_"]', 'a[href^="space-uid"]');
                blockUsers_('[id^="comment_"] > div', 'a.xi2.xw1'); // 点评
                break;
            case 'forum': // 各版块帖子列表
                blockUsers_('[id^="normalthread_"]', 'a[href^="space-uid"]');
                blockUsers_vfastpost(); // 预览帖子中的回复
                break;
            case 'search': // 搜索结果
                blockUsers_('.pbw', 'a[href^="space-uid"]');
                break;
            case 'notice': // 消息
                blockUsers_('dl.cl', '.ntc_body a[href^="space-uid"]');
                break;
            case 'pm': // 私人聊天
                blockUsers_('dl[id^="pmlist_"]', '.ptm.pm_c a[href^="space-uid"]');
                break;
        }

        function blockUsers_(list1, list2) {
            let listItem = document.querySelectorAll(list1);
            if (listItem.length < 1) return
            listItem.forEach(function(item){ // 遍历所有帖子
                menu_value('menu_customBlockUsers').forEach(function(item1){ // 遍历用户黑名单
                    let itemName = item.querySelector(list2); // 寻找用户名
                    if (itemName && itemName.innerText === item1) {
                        console.log(`屏蔽用户:${item1}`);
                        item.remove(); // 删除帖子
                    }
                })
            })
        }

        function blockUsers_vfastpost() {
            let vfastpost = e => {
                if (e.target.innerHTML && e.target.innerHTML.indexOf('id="vfastpost"') > -1) {
                    let listItem = e.target.querySelectorAll('.bm_c > [id^="post_"]');
                    if (listItem.length < 1) return
                    listItem.forEach(function(item){ // 遍历所有回复
                        menu_value('menu_customBlockUsers').forEach(function(item1){ // 遍历用户黑名单
                            let itemName = item.querySelector('a.xi2'); // 寻找用户名
                            if (itemName && itemName.innerText === item1) {
                                console.log(`屏蔽用户:${item1}`);
                                item.remove(); // 删除回复
                            }
                        })
                    })
                }
            }
            document.addEventListener('DOMNodeInserted', vfastpost); // 监听插入事件
        }
    }


    // 自定义屏蔽关键词(帖子标题)
    function customBlockKeywords() {
        let nowBlockKeywords = '';
        GM_getValue('menu_customBlockKeywords').forEach(function(item){nowBlockKeywords += '|' + item})
        let newBlockKeywords = prompt('编辑 [自定义屏蔽关键词],刷新网页后生效\n(不同关键词之间使用 "|" 分隔,\n(例如:助力|互助|互点,如果只有一个就不需要 "|" 了。', nowBlockKeywords.replace('|',''));
        if (newBlockKeywords === '') {
            GM_setValue('menu_customBlockKeywords', []);
            registerMenuCommand(); // 重新注册脚本菜单
        } else if (newBlockKeywords != null) {
            GM_setValue('menu_customBlockKeywords', newBlockKeywords.split('|'));
            registerMenuCommand(); // 重新注册脚本菜单
        }
    };


    // 屏蔽关键词(帖子标题)
    function blockKeywords() {
        if (!menu_value('menu_blockKeywords')) return
        if (!menu_value('menu_customBlockKeywords') || menu_value('menu_customBlockKeywords').length < 1) return
        let listItem = document.querySelectorAll('[id^="normalthread_"]');
        if (listItem.length < 1) return
        listItem.forEach(function(item){ // 遍历所有帖子标题
            menu_value('menu_customBlockKeywords').forEach(function(item1){ // 遍历关键词
                let itemName = item.querySelector('a.s.xst'); // 寻找帖子标题
                if (itemName && itemName.innerText.indexOf(item1) > -1) {
                    console.log(`屏蔽关键词:[${item1}]`, `,帖子标题:[${itemName.innerText}]`);
                    item.remove(); // 删除帖子
                }
            })
        })
    }


    // 监听插入事件(有新的回复主题,点击查看)
    function blockDOMNodeInserted() {
        let block = e => {
            if (e.target.innerText && e.target.innerText.indexOf('newthread') > -1) {
                setTimeout(function () {
                    blockUsers('forum'); //                           屏蔽用户(黑名单)
                    blockKeywords(); //                               屏蔽关键词(帖子标题)
                }, 100)
            }
        }
        document.addEventListener('DOMNodeInserted', block); // 监听插入事件
    }


    // 监听插入事件(预览快速回复带签名)
    function vfastpostDOMNodeInserted() {
        let vfastpost = e => {
            if (e.target.innerHTML && e.target.innerHTML.indexOf('id="vfastpost"') > -1) {
                e.target.getElementsByTagName('form')[0].insertAdjacentHTML('afterbegin', `<input type="hidden" name="usesig" value="1">`);
            }
        }
        document.addEventListener('DOMNodeInserted', vfastpost); // 监听插入事件
    }


    // 自定义小尾巴内容
    function customLittleTail() {
        let newLittleTail = prompt('编辑 [自定义小尾巴内容],刷新网页后生效(换行请使用 \\n\n提示①:记得在小尾巴前面加上几个 \\n 换行,用来分隔开回帖内容~\n提示②:建议使用 [align=right] 标签来使小尾巴居右~\n提示③:支持论坛富文本标签(建议先找个回复编辑预览好~\n示例:\\n\\n\\n\\n[align=right]第一行内容~\\n第二行内容~[/align]', GM_getValue('menu_customLittleTail'));
        if (newLittleTail === '') {
            GM_setValue('menu_customLittleTail', []);
            registerMenuCommand(); // 重新注册脚本菜单
        } else if (newLittleTail != null) {
            GM_setValue('menu_customLittleTail', newLittleTail);
            registerMenuCommand(); // 重新注册脚本菜单
        }
    };


    // 小尾巴
    function littleTail(type) {
        if (!menu_value('menu_customLittleTail')) return
        switch(type) {
            case 'forum': // 各版块帖子列表的预览帖子
                littleTail_0(); // 预览帖子 快速回复(底部)
                littleTail_1(); // 预览帖子 回复(悬浮)
                break;
            case 'thread': // 帖子内
                littleTail_1(); // 快速回复(悬浮)
                littleTail_2(); // 回复框(底部)
                break;
            case 'reply': // 高级回复
                littleTail_3();
                break;
        }

        function littleTail_0() {
            let vfastpost = e => {
                if (e.target.innerHTML && e.target.innerHTML.indexOf('id="vfastpost"') > -1) {
                    let message = e.target.querySelector('input[name="message"]'), id = message.id.match(/\d+/g)[0];
                    message.parentNode.innerHTML = `<textarea type="text" name="message" id="vmessage_${id}" style="width: 99.8%;height: 30px;border: none;outline: none;font-size: 14px;overflow-y: hidden;"></textarea>`
                    document.getElementById(`vreplysubmit_${id}`).onclick = function(){
                        if (GM_getValue('menu_customLittleTail')) document.getElementById(`vmessage_${id}`).value += GM_getValue('menu_customLittleTail').replaceAll('\\n', '\n');
                    }
                }
            }
            document.addEventListener('DOMNodeInserted', vfastpost); // 监听插入事件
        }

        function littleTail_1() {
            let floatlayout_reply = e => {
                if (e.target.innerHTML && e.target.innerHTML.indexOf('id="floatlayout_reply"') > -1) {
                    document.getElementById('postsubmit').onclick = function(){
                        if (GM_getValue('menu_customLittleTail')) document.getElementById('postmessage').value += GM_getValue('menu_customLittleTail').replaceAll('\\n', '\n');
                    }
                }
            }
            document.addEventListener('DOMNodeInserted', floatlayout_reply); // 监听插入事件
        }

        function littleTail_2() { // 帖子底部的回复框
            document.getElementById('fastpostsubmit').onclick = function(){
                if (GM_getValue('menu_customLittleTail')) document.getElementById('fastpostmessage').value += GM_getValue('menu_customLittleTail').replaceAll('\\n', '\n');
            }
        }

        function littleTail_3() {
            let postsubmit = document.getElementById('postsubmit');
            if (postsubmit && postsubmit.innerText === '\n参与/回复主题\n' || postsubmit && postsubmit.innerText === '\n发表帖子\n') {
                postsubmit.onclick = function(){
                    if (GM_getValue('menu_customLittleTail')) document.getElementById('e_textarea').value += GM_getValue('menu_customLittleTail').replaceAll('\\n', '\n');
                }
            }
        }
    }


    // 监听插入事件(回帖间隔)
    /*function replyIntervalDOMNodeInserted() {
        let replyInterval = e => {
            if (e.target.innerHTML && e.target.innerText.indexOf('发表回复 金钱+1') > -1) {
                setTimeout(function () {GM_notification({text: '过去 60 秒了,可以回帖了~', timeout: 3500});}, 60000)
            }
        }
        document.addEventListener('DOMNodeInserted', replyInterval); // 监听插入事件
    }*/


    // 自动翻页
    function pageLoading() {
        if (!menu_value('menu_pageLoading')) return
        if (curSite.SiteTypeID > 0){
            windowScroll(function (direction, e) {
                if (direction === "down") { // 下滑才准备翻页
                    let scrollTop = document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;
                    if (document.documentElement.scrollHeight <= document.documentElement.clientHeight + scrollTop + 999) {
                        if (curSite.SiteTypeID === SiteType.FORUM) { // 如果是各版块帖子列表则直接点下一页就行了
                            let autopbn = document.querySelector('#autopbn');
                            if (autopbn && autopbn.innerText === "下一页 »"){ // 如果已经在加载中了,就忽略
                                autopbn.click();
                                let timer = setInterval(function(){ // 在下一页加载完成后
                                    if (document.querySelector('#autopbn').innerText === "下一页 »") {
                                        if (menu_value('menu_delate255')) delate255(); // 隐藏 255 权限帖子
                                        if (menu_value('menu_blockUsers')) blockUsers('forum'); // 屏蔽用户(黑名单)
                                        if (menu_value('menu_blockKeywords')) blockKeywords(); // 屏蔽关键词(帖子标题)
                                        clearInterval(timer);
                                    }
                                }, 10);
                            }
                        }else{
                            ShowPager.loadMorePage();
                        }
                    }
                }
            });
        }
    }


    // 自动显示帖子内被隐藏的回复
    function showPosts() {
        if(menu_value('menu_showhide')){
            let showposts = document.querySelector('#hiddenpoststip a');
            if (showposts){ // 如果存在
                showposts.click();
            }
        }
    }


    // 隐藏帖子内的 [下一页] 按钮
    function hidePgbtn() {
        let style_hidePgbtn = document.createElement('style');
        style_hidePgbtn.innerHTML = `.pgbtn {display: none;}`;
        document.head.appendChild(style_hidePgbtn);
    }


    // 快捷回到顶部(右键左右两侧空白处)
    function backToTop() {
        document.body.oncontextmenu = function(event){
            if (event.target==this) {
                event.preventDefault();
                window.scrollTo(0,0)
            }
        }
    }


    // 收起帖子预览(左键左右两侧空白处)
    function collapsedNowPost() {
        document.body.onclick = function(event){
            if (event.target==this) {
                document.querySelectorAll('[id^="threadPreviewTR_"] .showhide').forEach(function (el) {
                    if (!el.parentNode.querySelector('[name="message"]') || el.parentNode.querySelector('[name="message"]').value === '' && !document.getElementById('fwin_reply')) { // 避免快速回复过程中误点收起了
                        let parentElement = el.parentNode.parentNode.parentNode.parentNode.parentNode,
                            top = parentElement.offsetTop + parentElement.offsetParent.offsetTop + parentElement.offsetParent.offsetParent.offsetTop; // 元素距离顶部的高度
                        if (top < document.documentElement.scrollTop) window.scrollTo(0,top) // 帖子标题在上面时才会滚动到该帖子处
                        el.click()
                    }
                });
            }
        }
    }


    // 显示在线状态
    function onlineStatus() {
        document.querySelectorAll('[id^="favatar"]').forEach(function(item){ // 遍历所有帖子
            let icon = (item.querySelector('[id^="userinfo"] > .i.y em').innerText === '当前在线') ? '🌝' : '🌚';
            let divStatus = document.createElement('div');
            divStatus.style = 'position: absolute;margin: -8px 0 0 8px;padding: 0 1px 1.2px;background-color: #ffffff;border-radius: 50%;';
            divStatus.innerText = icon;
            let mochu = item.querySelector('.avatar');
            mochu.parentNode.insertBefore(divStatus,mochu);
        })
    }


    // 自动隐藏阅读权限 255 的帖子
    function delate255() {
        if (patt_forum.test(location.pathname) || location.search.indexOf('mod=forumdisplay') > -1){
            let tbody = document.querySelectorAll('tbody[id^="normalthread_"] .xw1');
            Array.from(tbody).forEach(function (_this) {
                if (_this.innerText === '255') {
                    _this.parentNode.parentNode.parentNode.remove();
                }
            })
        }
    }


    // 滚动条事件
    function windowScroll(fn1) {
        var beforeScrollTop = document.documentElement.scrollTop,
            fn = fn1 || function () {};
        setTimeout(function () { // 延时执行,避免刚载入到页面就触发翻页事件
            window.addEventListener("scroll", function (e) {
                var afterScrollTop = document.documentElement.scrollTop,
                    delta = afterScrollTop - beforeScrollTop;
                if (delta == 0) return false;
                fn(delta > 0 ? "down" : "up", e);
                beforeScrollTop = afterScrollTop;
            }, false);
        }, 1000)
    }


    var ShowPager = { // 修改自 https://greasyfork.org/scripts/14178
        getFullHref: function (e) {
            if(e == null) return '';
            "string" != typeof e && (e = e.getAttribute("href"));
            var t = this.getFullHref.a;
            return t || (this.getFullHref.a = t = document.createElement("a")), t.href = e, t.href;
        },
        createDocumentByString: function (e) {
            if (e) {
                if ("HTML" !== document.documentElement.nodeName) return (new DOMParser).parseFromString(e, "application/xhtml+xml");
                var t;
                try {
                    t = (new DOMParser).parseFromString(e, "text/html");
                } catch (e) {
                }
                if (t) return t;
                if (document.implementation.createHTMLDocument) t = document.implementation.createHTMLDocument("ADocument"); else try {
                    (t = document.cloneNode(!1)).appendChild(t.importNode(document.documentElement, !1)),
                        t.documentElement.appendChild(t.createElement("head")), t.documentElement.appendChild(t.createElement("body"));
                } catch (e) {
                }
                if (t) {
                    var r = document.createRange();
                    r.selectNodeContents(document.body);
                    var n = r.createContextualFragment(e);
                    t.body.appendChild(n);
                    for (var a, o = {
                        TITLE: !0,
                        META: !0,
                        LINK: !0,
                        STYLE: !0,
                        BASE: !0
                    }, i = t.body, s = i.childNodes, c = s.length - 1; c >= 0; c--) o[(a = s[c]).nodeName] && i.removeChild(a);
                    return t;
                }
            } else console.error("没有找到要转成DOM的字符串");
        },
        loadMorePage: function () {
            if (curSite.pager) {
                let curPageEle = getElementByXpath(curSite.pager.nextLink);
                var url = this.getFullHref(curPageEle);
                //console.log(`${url} ${curPageEle} ${curSite.pageUrl}`);
                if(url === '') return;
                if(curSite.pageUrl === url) return;// 不会重复加载相同的页面
                curSite.pageUrl = url;
                // 读取下一页的数据
                curSite.pager.startFilter && curSite.pager.startFilter();
                GM_xmlhttpRequest({
                    url: url,
                    method: "GET",
                    timeout: 5000,
                    onload: function (response) {
                        try {
                            var newBody = ShowPager.createDocumentByString(response.responseText);
                            let pageElems = getAllElements(curSite.pager.pageElement, newBody, newBody);
                            let toElement = getAllElements(curSite.pager.HT_insert[0])[0];
                            if (pageElems.length >= 0) {
                                let addTo = "beforeend";
                                if (curSite.pager.HT_insert[1] == 1) addTo = "beforebegin";
                                // 插入新页面元素
                                pageElems.forEach(function (one) {
                                    toElement.insertAdjacentElement(addTo, one);
                                });
                                if (menu_value('menu_blockUsers')) { // 屏蔽用户(黑名单)
                                    if (patt_thread.test(location.pathname) || location.search.indexOf('mod=viewthread') > -1) {
                                        blockUsers('thread');
                                    } else if (location.pathname === '/search.php') {
                                        blockUsers('search');
                                    }
                                }
                                // 替换待替换元素
                                try {
                                    let oriE = getAllElements(curSite.pager.replaceE);
                                    let repE = getAllElements(curSite.pager.replaceE, newBody, newBody);
                                    if (oriE.length === repE.length) {
                                        for (var i = 0; i < oriE.length; i++) {
                                            oriE[i].outerHTML = repE[i].outerHTML;
                                        }
                                    }
                                } catch (e) {
                                    console.log(e);
                                }
                            }
                        } catch (e) {
                            console.log(e);
                        }
                    }
                });
            }
        },
    };


    function getElementByXpath(e, t, r) {
        r = r || document, t = t || r;
        try {
            return r.evaluate(e, t, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
        } catch (t) {
            return void console.error("无效的xpath");
        }
    }


    function getAllElements(e, t, r, n, o) {
        let getAllElementsByXpath = function(e, t, r) {
            return r = r || document, t = t || r, r.evaluate(e, t, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
        }

        var i, s = [];
        if (!e) return s;
        if (r = r || document, n = n || window, o = o || void 0, t = t || r, "string" == typeof e) i = 0 === e.search(/^css;/i) ? function getAllElementsByCSS(e, t) {
            return (t || document).querySelectorAll(e);
        }(e.slice(4), t) : getAllElementsByXpath(e, t, r); else {
            if (!(i = e(r, n, o))) return s;
            if (i.nodeType) return s[0] = i, s;
        }
        return function makeArray(e) {
            var t, r, n, o = [];
            if (e.pop) {
                for (t = 0, r = e.length; t < r; t++) (n = e[t]) && (n.nodeType ? o.push(n) : o = o.concat(makeArray(n)));
                return a()(o);
            }
            if (e.item) {
                for (t = e.length; t;) o[--t] = e[t];
                return o;
            }
            if (e.iterateNext) {
                for (t = e.snapshotLength; t;) o[--t] = e.snapshotItem(t);
                return o;
            }
        }(i);
    }


    // 通过 Cookie 来判断是否登录
    function getLoginStatus() {
        let cookie = document.cookie.split(';');
        for (let i=0; i<cookie.length; i++) {if (cookie[i].trim().indexOf('hkCM_2132_checkpm=') === 0) return true;}
        return false;
    }
})();