baxitv_find_preview

查找预览

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         baxitv_find_preview
// @namespace    com.oldtan.find_preview
// @version      1.1.9
// @description  查找预览
// @author       oldtan
// @include       https://www.baxi.tv/forum-54-*.html
// @icon         
// @grant        none


// ==/UserScript==
function sleep(time){
    var timeStamp = new Date().getTime();
    var endTime = timeStamp + time;
    while(true){
        if (new Date().getTime() > endTime){
            return;
        }
    }
}

window.addEventListener('load', function() {
    //console.log(123111111111111111111111111111)
    // // 获取所有的超链接元素
    // var links = document.querySelectorAll('a');
    // // 遍历这些超链接并检查文本内容
    // links.forEach(function(link) {
    //      // 检查超链接文本是否等于 '预览'
    //     if (link.textContent === '预览') {
    //         // 获取超链接所在的 tbody 元素的 ID
    //         var tbodyElement = link.closest('tbody');
    //         if (tbodyElement.id.includes('stick')){
    //             return
    //         }
    //         if (tbodyElement) {
    //             // 提取 tid,这里假设 tbody 的 ID 是 'thread_' + tid
    //             var tid = tbodyElement.id.replace('normalthread_', '');
    //             // 调用 forum.js 中的 previewThread 函数
    //             previewThread(tid, tbodyElement.id);
    //             // 确保预览元素可见
    //             var previewDiv = document.getElementById('threadPreviewTR_' + tid);
    //             if (previewDiv) {
    //                 previewDiv.style.display = 'revert';
    //             }
    //         }
    //     }
    // });

   

    var scbar = document.getElementById('scbar');
    var scbar_hot = document.getElementById('scbar_hot');

    // 获取 div 内的所有 <a> 元素
    var links = scbar_hot.getElementsByTagName('*');
    // 倒序遍历并删除所有 <a> 元素
    for (var i = links.length - 1; i >= 0; i--) {
        links[i].parentNode.removeChild(links[i]);
    }
    document.getElementsByClassName('scbar_hot_td')[0].style.width='60%';
    scbar_hot.addEventListener('click', function(e) {
         // 获取所有的超链接元素
        var links = document.querySelectorAll('a');
        // 遍历这些超链接并检查文本内容
        links.forEach(function(link) {
            // 检查超链接文本是否等于 '预览'
            if (link.textContent === '预览') {
                // 获取超链接所在的 tbody 元素的 ID
                var tbody = link.closest('tbody').getAttribute('id');
                if (tbody.includes('stick')){
                    return
                }
                if (tbody) {
                    // 提取 tid,这里假设 tbody 的 ID 是 'thread_' + tid
                    var tid = tbody.split('_')[1];
                    // 调用 forum.js 中的 previewThread 函数
                    previewThread(tid, tbody);
                    // 确保预览元素可见
                    var previewDiv = document.getElementById('threadPreviewTR_' + tid);
                    if (previewDiv) {
                        previewDiv.style.display = 'revert';
                    }
                }
            }
        });

    });

    // 初始化时设置 scbar 的样式
    // setScrollStyle(scbar);

    // 隐藏热搜关键字
    var hotkwdDiv = document.getElementById('scbar_hot');
    if (hotkwdDiv) {
        // hotkwdDiv.style.display = 'none';
    }
    var navbar = document.getElementById('scbar');
    var navbarOffsetTop = navbar.offsetTop; // 导航栏距离页面顶部的距离
    var isScrollStyle=false
    window.addEventListener('scroll', function() {
        var scrollTop = window.pageYOffset || document.documentElement.scrollTop;

        if (scrollTop > navbarOffsetTop) {
            setScrollStyle(scbar);
            isScrollStyle=true
        } else {
            setInitialStyle(scbar);
            isScrollStyle=false
        }
    });
    // 添加键盘事件监听器
    document.addEventListener('keydown', function(event) {
        // 检查是否同时按下了 Ctrl 和 'F' 或 'S' 键
        // if (event.ctrlKey && (event.key === 'D' || event.key === 'S')) {
        if (event.key === 'Tab') {
            // 阻止默认的 Tab 行为
            event.preventDefault();
            // 获取输入框元素
            var input = document.getElementById('scbar_txt');
            // 让输入框获取焦点
            input.focus();
            // 选中输入框中的所有文本
            input.select();
        }
    });

    // 获取搜索提交按钮和搜索输入框
    var searchButton = document.getElementById('scbar_btn');
    var searchInput = document.getElementById('scbar_txt');
    var searchForm = document.getElementById('scbar_form');

    // searchButton.addEventListener('click', function() {
    searchForm.addEventListener('submit', function(event) {
        event.preventDefault(); // 阻止表单默认的提交
        var scrollTop = window.pageYOffset || document.documentElement.scrollTop;
        //先隐藏所有预览
        hidePreview();
        //移除之前的高亮显示
        removeHighlight();
        // 获取搜索框的值
        var searchValue = searchInput.value.toLowerCase();
        var displayElement = document.getElementById('scbar_type');
        if (searchValue) {
            // 获取所有超链接
            var links = document.getElementsByClassName('s xst');
            var matchCount = 0; // 重置匹配计数器
            var firstMatch = null; // 存储第一个匹配的超链接
            // 遍历超链接
            for (var i = 0; i < links.length; i++) {
                var link = links[i];
                // 检查超链接文本是否包含搜索值
                if (link.textContent.toLowerCase().includes(searchValue)) {
                    // 打印匹配的超链接文本内容
                    // console.log(link.textContent);
                    matchCount++;
                    // 高亮显示匹配的超链接文本
                    highlightText(link, searchValue);
                    // 获取超链接所在的 tbody 元素的 ID
                    var tbody = link.closest('tbody').getAttribute('id');
                    if (tbody.includes('stick')){
                        return
                    }
                    if (tbody) {
                        // 提取 tid,这里假设 tbody 的 ID 是 'thread_' + tid
                        var tid = tbody.split('_')[1];
                        // 调用 forum.js 中的 previewThread 函数
                        previewThread(tid, tbody);
                        // 确保预览元素可见
                        var previewDiv = document.getElementById('threadPreviewTR_' + tid);
                        if (previewDiv) {
                            previewDiv.style.display = 'revert';
                        }
                        if (!firstMatch) {
                            firstMatch = link; // 存储第一个匹配的超链接
                            if(!isScrollStyle){
                                setScrollStyle(scbar);//不设置的话搜索到的关键字正好是第一个,显示有异样
                            }
                            // 找到当前链接的父节点
                            var previousElement = firstMatch.closest('tbody').previousElementSibling;
                            if(previousElement.nodeName==='SCRIPT'){
                                previousElement=previousElement.previousElementSibling.previousElementSibling;
                            }

                            console.log(previousElement)
                            previousElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
                        }
                    }
                }
            }
            if(firstMatch){

                // if(isScrollStyle){
                    // console.log(previousElement+scrollTop)
                    // previousElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
                // }else{
                    // previousElement = previousElement.previousElementSibling.previousElementSibling;
                    // console.log(previousElement)
                    // previousElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
                    // var stickElement = document.getElementById('threadlist');//threadlist
                    // stickElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
                // }
            }
            displayElement.textContent = matchCount;
        } else {
            console.log('Please enter a search term.');
            displayElement.textContent = 0;
        }
        // 使用 setTimeout 延迟获取所有类名为 'previewvfastpost' 的元素
        setTimeout(function() {
            var elements = document.getElementsByClassName('previewvfastpost');
            // console.log(elements.length);
            // 遍历所有元素并隐藏它们
            for (var j = 0; j < elements.length; j++) {

                elements[j].style.display = 'none';

            }
        }, 500); // 毫秒
    });


});

function hidePreview(){
    // 获取所有的超链接元素
    var links = document.querySelectorAll('a');
    // 遍历这些超链接并检查文本内容
    links.forEach(function(link) {
        // 检查超链接文本是否等于 '预览'
        if (link.textContent === '隐藏预览') {
            // 获取超链接所在的 tbody 元素的 ID
            var tbody = link.closest('tbody').getAttribute('id');
            if (tbody.includes('stick')){
                return
            }
            if (tbody) {
                // 提取 tid,这里假设 tbody 的 ID 是 'thread_' + tid
                var tid = tbody.split('_')[1];
                // 调用 forum.js 中的 previewThread 函数
                previewThread(tid, tbody);
                // 确保预览元素可见
                var previewDiv = document.getElementById('threadPreviewTR_' + tid);
                if (previewDiv) {
                    previewDiv.style.display = 'revert';
                }
            }
        }
    });

}

// 函数:高亮显示匹配的文本
function highlightText(element, searchValue) {
    var innerHTML = element.innerHTML; // 获取元素的原始HTML
    var highlighted = innerHTML.replace(new RegExp(searchValue, 'gi'), function(match) {
        return '<span class="ai-assist-highlight">' + match + '</span>'; // 将匹配的文本包裹在span中,并添加高亮样式类
    });
    element.innerHTML = highlighted; // 更新元素的HTML以显示高亮文本
}

// 移除高亮显示的函数
function removeHighlight() {
    var highlights = document.querySelectorAll('.ai-assist-highlight');
    highlights.forEach(function(el) {
        // 将高亮文本的父级超链接的文本内容恢复原样
        var parentLink = el.parentNode;
        parentLink.innerHTML = parentLink.textContent;
    });
}

// 定义初始化样式
function setInitialStyle(scbar) {
    scbar.style.overflow = 'hidden';
    scbar.style.height = '42px';
    scbar.style.lineHeight = '42px';
    scbar.style.borderTop = '1px solid #FFF';
    scbar.style.borderBottom = '1px solid #E9EFF5';
    scbar.style.background = '#E8EFF5';
    scbar.style.position = 'static'; // 非固定定位
    // scbar.style.left = '234.667px';
    scbar.style.zIndex = '199';
    scbar.style.top = '0px';
}

// 定义滚动时的样式
function setScrollStyle(scbar) {
    scbar.style.borderLeftWidth = '0px';
    scbar.style.borderRightWidth = '0px';
    scbar.style.height = '42px';
    scbar.style.lineHeight = '42px';
    scbar.style.width = '960px';
    scbar.style.position = 'fixed';
    scbar.style.opacity = '1';
    // scbar.style.left = '234.667px';
    scbar.style.zIndex = '199';
    scbar.style.top = '0px';
}
function Toast(msg,duration){
      duration=isNaN(duration)?3000:duration;
      var m = document.createElement('div');
      m.innerHTML = msg;
      m.style.cssText="max-width:60%;min-width: 150px;padding:0 14px;height: 60px;color: rgb(255, 255, 255);line-height: 60px;text-align: center;border-radius: 4px;position: fixed;top: 40%;left: 50%;transform: translate(-50%, -50%);z-index: 999999;background: rgba(0, 0, 0,.7);font-size: 16px;";
      document.body.appendChild(m);
      setTimeout(function() {
        var d = 0.5;
        m.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in';
        m.style.opacity = '0';
        setTimeout(function() { document.body.removeChild(m) }, d * 1000);
      }, duration);
    }


function Toast2(msg,duration){
      duration=isNaN(duration)?3000:duration;
      var m = document.createElement('div');
      m.innerHTML = msg;
      m.style.cssText="max-width:60%;min-width: 150px;padding:0 14px;height: 60px;color: rgb(255, 255, 255);line-height: 60px;text-align: center;border-radius: 4px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 999999;background: rgba(0, 0, 0,.7);font-size: 16px;";
      document.body.appendChild(m);
      setTimeout(function() {
        var d = 0.5;
        m.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in';
        m.style.opacity = '0';
        setTimeout(function() { document.body.removeChild(m) }, d * 1000);
      }, duration);
    }