Greasy Fork

虎扑黑名单

虎扑黑名单,隐藏拉黑的帖子

当前为 2023-12-09 提交的版本,查看 最新版本

// ==UserScript==
// @name         虎扑黑名单
// @description  虎扑黑名单,隐藏拉黑的帖子
// @author       Amamiya
// @icon         https://w1.hoopchina.com.cn/images/pc/old/favicon.ico
// @match        https://bbs.hupu.com/*
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_deleteValue
// @grant        GM_registerMenuCommand
// @grant        GM_addStyle
// @require      https://code.jquery.com/jquery-3.6.0.min.js
// @require      https://code.jquery.com/ui/1.12.1/jquery-ui.min.js
// @license MIT
// @version 1.2.0
// @namespace https://greasyfork.org/users/801480
// ==/UserScript==

(function () {
    'use strict';
    window.onload = function () {
        var currentURL = window.location.href;
        const hiddenUserListString = GM_getValue('hiddenUserList', '');
        const hiddenKeywordListString = GM_getValue('hiddenKeywordList', '');



        if (!currentURL.includes('.html')) {


            
        if (hiddenUserListString||hiddenKeywordListString) {
            const hiddenUserList = hiddenUserListString.split(',');
            const hiddenKeywordList = hiddenKeywordListString.split(',');
            const posts = document.querySelectorAll('.bbs-sl-web-post-layout');
            posts.forEach(post => {
                const postAuthor = post.children[2].textContent;
                const postTitle = post.children[0].textContent;
                if (hiddenUserListString&&hiddenUserList.includes(postAuthor)) {
                    post.closest('li').style.display = 'none';
                }
                if (hiddenKeywordListString&&hiddenKeywordList.some(item => postTitle.includes(item))) {
                    post.closest('li').style.display = 'none';
                }
            });

        }

            const posts = document.querySelectorAll('.post-auth');
            posts.forEach(post => {
                const span = document.createElement('span');
                span.textContent = '黑';
                span.style.cursor = 'pointer';
                span.style.color = 'red';
                span.style.marginRight = '10px';
                if (post.firstChild) {
                    post.insertBefore(span, post.firstChild);
                } else {
                    post.appendChild(span);
                }
                span.addEventListener('click', function (event) {
                    const id = event.target.parentElement.querySelector('a').textContent;
                    if (confirm('是否确定将用户 "' + id + '" 拉入黑名单?')) {
                        let hiddenUserList = GM_getValue('hiddenUserList', '');
                        if (hiddenUserList === '') {
                            hiddenUserList = id;
                        } else {
                            hiddenUserList += ',' + id;
                        }
                        GM_setValue('hiddenUserList', hiddenUserList);
                        event.target.closest('li').style.display = 'none';
                    }
                });
            });


        } else {
            const posts = document.querySelectorAll('.user-base-info');
            posts.forEach(post => {
                const span = document.createElement('span');
                span.textContent = '黑';
                span.style.cursor = 'pointer';
                span.style.color = 'red';
                span.style.marginRight = '10px';
                post.insertBefore(span, post.childNodes[1]);
                span.addEventListener('click', function (event) {
                    const id = event.target.parentElement.querySelector('a').textContent;
                    if (confirm('是否确定将用户 "' + id + '" 拉入黑名单?')) {
                        let hiddenUserList = GM_getValue('hiddenUserList', '');
                        if (hiddenUserList === '') {
                            hiddenUserList = id;
                        } else {
                            hiddenUserList += ',' + id;
                        }
                        GM_setValue('hiddenUserList', hiddenUserList);
                        event.target.closest('.post-reply-list-wrapper').style.display = 'none';

                    }
                });
            });

            if (hiddenUserListString) {
                const hiddenUserList = hiddenUserListString.split(',');
                const posts = document.querySelectorAll('.user-base-info');
                console.log(posts)
                posts.forEach(post => {
                    const postAuthor = post.querySelector('a').textContent;
                    if (hiddenUserList.includes(postAuthor)) {
                        post.closest('.post-reply-list-wrapper').style.display = 'none';
                    }
                });

            }

        }
        GM_registerMenuCommand('移除黑名单', function () {
            const hiddenUserListString = GM_getValue('hiddenUserList', '');
            if (hiddenUserListString) {
                const hiddenUserList = hiddenUserListString.split(',');
                const htmlList = hiddenUserList.map(user => "<div class='userItem'>" + user + "</div>").join('');
                const html = "<div id='removeBlacklistDialog'><div class='title'>选择要移除的用户:</div><div id='userList'>" + htmlList + "</div><button id='closeButton'>关闭</button></div>";
                const div = document.createElement('div');
                div.innerHTML = html;
                document.body.appendChild(div);

                document.getElementById('closeButton').addEventListener('click', function () {
                    div.remove();
                });

                const userList = document.getElementById('userList');
                userList.addEventListener('click', function (event) {
                    if (event.target.classList.contains('userItem')) {
                        const userInput = event.target.textContent;
                        const index = hiddenUserList.indexOf(userInput);
                        hiddenUserList.splice(index, 1);
                        const updatedHiddenUserList = hiddenUserList.join(',');
                        GM_setValue('hiddenUserList', updatedHiddenUserList);
                        userList.innerHTML = hiddenUserList.map(user => "<div class='userItem'>" + user + "</div>").join('');
                    }
                });
                $('#removeBlacklistDialog').draggable();
            } else {
                alert('当前黑名单为空');
            }
        });

        GM_registerMenuCommand('关键词屏蔽', function () {
            const hiddenKeywordListString = GM_getValue('hiddenKeywordList', '');
            const html = "<div id='keywordBlockDialog'><div class='title'>输入要屏蔽的关键词,用英文逗号隔开:</div><input type='text' id='keywordInput' value='" + hiddenKeywordListString + "'><div id='buttonContainer'><button id='saveButton'>保存</button><button id='closeButton'>关闭</button></div></div>";
            const div = document.createElement('div');
            div.innerHTML = html;
            document.body.appendChild(div);

            document.getElementById('closeButton').addEventListener('click', function () {
                div.remove();
            });

            document.getElementById('saveButton').addEventListener('click', function () {
                const updatedHiddenKeywordList = document.getElementById('keywordInput').value;
                GM_setValue('hiddenKeywordList', updatedHiddenKeywordList);
                div.remove();
            });

            $('#keywordBlockDialog').draggable();
        });


    };


})();

GM_addStyle(`
    #removeBlacklistDialog {
        position: fixed;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        background-color: #f9f9f9;
        border: 1px solid #ccc;
        padding: 10px;
        text-align: center;
    }
            .title {
                font-weight: bold;
                font-size: 16px;
                margin-bottom: 10px;
            }
            #userList {
                margin-bottom: 20px;
            }
            #closeButton {
                position: absolute;
                bottom: 10px;
                right: 10px;
            }
            .userItem {
                margin:10px;
            }

            #keywordBlockDialog {
                display: flex;
                flex-direction: column;
                align-items: center;
                position: fixed;
                top: 50%;
                left: 50%;
                transform: translate(-50%, -50%);
                background-color: #f9f9f9;
                border: 1px solid #ccc;
                padding: 10px;
                text-align: center;
            }
            #keywordInput {
                width: 80%;
                height: 30px;
                margin-bottom: 20px;
            }
            #buttonContainer {
                display: flex;
                justify-content: center;
                width: 100%;
            }


`);