Sleazy Fork is available in English.

海角社区

目前可以用,可以查看金币钻石视频,需要手动注册登录

// ==UserScript==
// @name         海角社区
// @namespace    http://tampermonkey.net/
// @version      8.00
// @description  目前可以用,可以查看金币钻石视频,需要手动注册登录
// @author       None
// @license      MIT
// @match       https://tools.thatwind.com/tool*
// @match        https://*/post/details*
// @icon         https://hjbc30.top/images/common/project/favicon.ico
// @run-at      document-start
// @grant       unsafeWindow
// @grant        GM_download
// @grant        GM_openInTab
// @grant        GM_xmlhttpRequest
// @grant        GM_xmlhttpRequest
// @connect      *
// @require      https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js
// ==/UserScript==


function pwd() {
    let word = ''
    let a = '48/46/116/115'
    let b = a.split('/')
    for (let c in b) {
        let d = parseInt(b[c])
        let e = String.fromCharCode(d)
        word = word + e
    }
    return word
}

function clearContainer(container) {
    if (container.hasChildNodes()) {
        container.innerHTML = "";
        container.style.border = "";
    }
}
function getContainer() {
    const existContainer = document.querySelector(".big-img-container-c");
    if (!existContainer) {
        const container = document.createElement("div");
        container.className = "big-img-container-c";
        container.style.position = "fixed";
        container.style.top = 0;
        container.style.left = 0;
        container.style.zIndex = 999999;
        container.onclick = function () {
            clearContainer(container);
        };
        document.querySelector("html").appendChild(container);
        return container;
    }
    return existContainer;
}




(function () {
    'use strict';


    /*
    
        if (location.host === "tools.thatwind.com" || location.host === "localhost:3000") {
            alert("sdfdsf")
        }
    */


    let newurl = ""
    let downloadurl = ""
    let fasongtext = ""
    let isphone = IsPhone()
    if (isphone) {
        $("body").append(" <div id='myDiv'; style='right: 3px;width: 40px;height: 40px;font-size: 12px;border-radius:50%; bottom: 120px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>打赏脚本</div>");
        $("body").append(" <div id='dmyDiv'; style='right: 3px;width: 40px;height: 40px;font-size: 12px;border-radius:50%; bottom: 160px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>下载</div>");
        $("body").append(" <div id='jxmyDiv'; style='right: 3px;width: 40px;height: 40px;font-size: 12px;border-radius:50%; bottom: 200px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>等待解析</div>");
        $("body").append(" <div id='jxspmyDiv'; style='right: 3px;width: 40px;height: 40px;font-size: 12px;border-radius:50%; bottom: 240px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>准备中</div>");
    }
    else {
        $("body").append(" <div id='myDiv'; style='right: 3px;width: 50px;height: 50px;font-size: 16px;border-radius:50%; bottom: 120px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>打赏脚本</div>");
        $("body").append(" <div id='dmyDiv'; style='right: 3px;width: 50px;height: 50px;font-size: 16px;border-radius:50%; bottom: 170px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>下载</div>");
        $("body").append(" <div id='jxmyDiv'; style='right: 3px;width: 50px;height: 50px;font-size: 16px;border-radius:50%; bottom: 220px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>等待解析</div>");
        $("body").append(" <div id='jxspmyDiv'; style='right: 3px;width: 50px;height: 50px;font-size: 16px;border-radius:50%; bottom: 270px;background: #FF6666;color:#ffffff;overflow: hidden;z-index: 9999;position: fixed;padding:5px;text-align:center;'>准备中</div>");
    }

    var jxspmyDiv = document.getElementById("jxspmyDiv"); // 获取到id为"myDiv"的div元素
    jxspmyDiv.addEventListener('click', function (e) {
        if (fasongtext.indexOf("IV=") === -1 || fasongtext.indexOf("包含") === -1|| fasongtext.indexOf("[--秒]") > -1) {
            jxspmyDiv.innerHTML = "解析失败"
            alert("解析失败,请刷新重试")
            return
        }
        jxspmyDiv.innerHTML = "解析中"
        fasong(fasongtext)

    });


    var jxmyDiv = document.getElementById("jxmyDiv"); // 获取到id为"myDiv"的div元素
    jxmyDiv.addEventListener('click', function (e) {
        const textarea = document.createElement('textarea');
        textarea.value = downloadurl;
        document.body.appendChild(textarea);
        textarea.select();
        document.execCommand('copy');
        document.body.removeChild(textarea);
        console.log("downloadurl="+downloadurl);
        alert("复制下载链接成功");
        //jxmyDiv.innerHTML = "fff"


    });


    var dmyDiv = document.getElementById("dmyDiv"); // 获取到id为"myDiv"的div元素
    dmyDiv.addEventListener('click', function (e) {
        //alert("你点击了DIV!"); // 当点击该div时会触发此函数并显示提示信息
        var currentUrl = window.location.href;
        // 输出当前网址

        let url = "https://tools.thatwind.com/tool/m3u8downloader#m3u8="
        let url2 = "&referer=" + currentUrl + "&filename=%E6%B5%B7%E8%A7%92%E7%A4%BE%E5%8C%BA"
        let url3 = url + newurl + url2
        GM_openInTab(url3, { active: true });
        console.log(url3);
        //window.location.href = url;
        //window.open(url, "_blank");


    });




    var myDiv = document.getElementById("myDiv"); // 获取到id为"myDiv"的div元素
    myDiv.addEventListener('click', function (e) {
        //alert("你点击了DIV!"); // 当点击该div时会触发此函数并显示提示信息
        const container = getContainer();
        const halfWidth = window.innerWidth / 2;
        const halfHeight = window.innerHeight / 2;
        clearContainer(container);


        if (isphone) {
            const containerX = halfWidth - 160;
            const containerY = halfHeight - 140;
            container.style.left = `${containerX}px`;
            container.style.top = `${containerY}px`;
            container.style.border = "1px solid #000";
            const bigImg = e.target.cloneNode();
            container.appendChild(bigImg);
            // 创建img标签并设置src属性为要显示的图片链接
            var img = document.createElement('img');
            img.setAttribute("src", "https://greasyfork.org/rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsiZGF0YSI6MTI4MDAzLCJwdXIiOiJibG9iX2lkIn19--362fa984de7dac0a445a418359f3b592c792ade4/360%E6%88%AA%E5%9B%BE20240109152050379.jpg?locale=zh-CN");
        }
        else {
            const containerX = halfWidth - 200;
            const containerY = halfHeight - 140;
            container.style.left = `${containerX}px`;
            container.style.top = `${containerY}px`;
            container.style.border = "1px solid #000";
            const bigImg = e.target.cloneNode();
            container.appendChild(bigImg);
            // 创建img标签并设置src属性为要显示的图片链接
            var img = document.createElement('img');
            img.setAttribute("src", "https://greasyfork.org/rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsiZGF0YSI6MTI3OTQ5LCJwdXIiOiJibG9iX2lkIn19--9723e102c10049b845a51a29b15a9fea2b66f03c/360%E6%88%AA%E5%9B%BE20240108163227692.jpg?locale=zh-CN");

        }


        var bodyElement = document.getElementsByClassName('big-img-container-c')[0];
        bodyElement.appendChild(img);


    });
    function decode(s) {
        return atob(atob(atob(s)));
    }

    function encode(s) {
        return btoa(btoa(btoa(s)));
    }

    function jencode(s) {
        return encode(JSON.stringify(s, `utf-8`));
    }

    function get_real_m3u8_path(url) {
        var request = new XMLHttpRequest();
        request.open('GET', url, false);
        request.send(null);
        if (request.status !== 200) {
            console.log(`解析失败!`);
            return url;
        }
        let ts_path = request.responseText.split('\n')[6];
        let id = ts_path.match(/([\w_]+_?)[\d]+.ts/)[1];
        let rurl = url.replace(/([\w_]+).m3u8/, `${id}.m3u8`);
        return rurl;
    }
    function runAsync(url, send_type, data_ry) {
        console.log("请求开始");
        var p = new Promise((resolve, reject) => {
            GM_xmlhttpRequest({
                method: send_type,
                url: url,
                headers: {
                    "Content-Type": "application/x-www-form-urlencoded;charset=utf-8"
                },
                data: data_ry,
                onload: function (response) {
                    console.log("请求成功");
                    //console.log(response.responseText);
                    resolve(response.responseText);
                },
                onerror: function (response) {
                    console.log("请求失败");
                    alert("解析失败,检查脚本是否有更新")
                    reject("请求失败");

                }
            });
        })
        //console.log("p="+p);
        return p;
    }
    function get_user_dict(host, id) {
        var url = `https://${host}.com/api/topic/node/topics?page=1&userId=${id}&type=0`;
        var request = new XMLHttpRequest();
        request.open('GET', url, false);
        request.send(null);
        if (request.status !== 200) {
            console.log(`用户信息解析失败!`);
            return {};
        }
        let p = JSON.parse(request.responseText, `utf-8`).data;
        p = JSON.parse(decode(p), `utf-8`);
        let total = p.page.total;
        let uid = `[banned]`;
        if (`results` in p) {
            uid = p.results[0].user.nickname + ` ` + uid;
        }
        return {
            'isFavorite': false,
            'likeCount': 12,
            'user': {
                'id': parseInt(id),
                'nickname': uid,
                'avatar': '29',
                'description': `hj community`,
                'topicCount': total,
                'videoCount': 0,
                'commentCount': 303,
                'fansCount': 57,
                'favoriteCount': 39,
                'status': 0,
                'sex': 1,
                'vip': 0,
                'vipExpiresTime': '0001-01-01 00:00:00',
                'certified': false,
                'certVideo': false,
                'certProfessor': false,
                'famous': false,
                'forbidden': false,
                'tags': null,
                'role': 0,
                'popularity': 10,
                'diamondConsume': 0,
                'title': { 'id': 0, 'name': '', 'consume': 0, 'consumeEnd': 0, 'icon': '' },
                'friendStatus': false,
                'voiceStatus': false,
                'videoStatus': false,
                'voiceMoneyType': 0,
                'voiceAmount': 0,
                'videoMoneyType': 0,
                'videoAmount': 0,
                'depositMoney': 0
            }
        }
    }

    function destory() {
        document.getElementsByClassName('preview-title')[0].remove()
    }



    function remove_vip(body) {
        body.node.vipLimit = 0;
        let attachments = body.attachments;
        let image_urls = [];
        let video_urls = ``;
        let has_video = -1;
        for (var i = 0; i < attachments.length; i++) {
            var atta = attachments[i];
            if (atta.category === 'images') {
                image_urls.push(`<img src="${atta.remoteUrl}" data-id="${atta.id}"/>`)
            }
            if (atta.category === 'video') {
                has_video = i;
            }
        }
        let images = image_urls.join();
        if (has_video >= 0) {
            let [nbody, v] = replace_m3u8(body, has_video);
            body = nbody;
            video_urls = `<video src="${v.remoteUrl}" data-id="${v.id}"/></video>`
        }
        let content = body.content.replace(/\[[图片视频]+\]?/, ``);
        content = body.content.replace(/此处内容售价.*?您还没有购买,请购买后查看!/, ``);
        content = '<html><head></head><body>' + content + '<br/>' + images + '<br/>' + video_urls + '<br/></body></html>';
        body.content = content;
        return body;
    }
    async function play(url) {
        console.log("url=" + url)
        let isphone = IsPhone()
        let playpos = ''
        if (isphone) {
            //document.querySelector('.sell-btn').remove()
            playpos = '.sell-btn'
            let videoInfo = document.querySelector(playpos)
            videoInfo.innerHTML = '<video id="video" controls autoplay width="100%"></video>'
            var video = document.getElementById('video');
            var hls = new Hls();
            // bind them together
            console.log("11");
            hls.attachMedia(video);
            hls.on(Hls.Events.MEDIA_ATTACHED, function () {
                console.log("video and hls.js are now bound together !");

                hls.loadSource(url);
                hls.on(Hls.Events.MANIFEST_PARSED, function (event, data) {
                    console.log("manifest loaded, found " + data.levels.length + " quality level");
                });
            });
        }
        else {
            playpos = '.sell-btn'
            window.dp = new DPlayer({
                element: document.querySelector(playpos),
                autoplay: false,
                theme: '#FADFA3',
                loop: true,
                lang: 'zh',
                screenshot: true,
                hotkey: true,
                preload: 'auto',
                video: {
                    url: url,
                    type: 'hls'
                }
            })
        }
    }


    

    function hasClass(element, className) {
        return element.classList.contains(className);
    }
    async function replace_m3u8(body, has_video) {
        jxspmyDiv.innerHTML = "准备中"
        jxmyDiv.innerHTML = " 等待解析"
        let attachments = body.attachments;
        let vidx = has_video;
        if (vidx < 0) {
            return [body, undefined];
        }
        if (body.sale === null || body.sale.money_type == 0) {
            return [body, attachments[vidx]];
        }
        let url = attachments[vidx].remoteUrl;
        console.log("url", url)


        let res = await fetch("https://hjbdc8.top" + url, {
            method: 'get',
        })
        let m3u8Text = await res.text()
        var textsent = m3u8Text
        let isphone = IsPhone()
        if (isphone) {
            var div = document.getElementsByClassName("nologin")[0]; // 获取第一个符合条件的元素
            console.log('div=', div);
            if (typeof div === 'undefined') {
                // do something

            } else {
                alert("请先登录-m")
                return
            }

            var i = 1;
            var intervalId = setInterval(function () {
                // 获取需要判断的元素
                let infolist = document.getElementsByClassName('html-box ishide')[0]
                infolist.className = 'html-box';
                let infophone = document.getElementsByClassName('preview-btn')[0]

                if (infophone) {

                    textsent = infophone.innerText + "***" + textsent
                    console.log(textsent);
                    if (textsent.indexOf("IV=") === -1 || textsent.indexOf("包含") === -1|| textsent.indexOf("[--秒]") > -1) {
                        jxspmyDiv.innerHTML = "解析失败"
                        alert("准备失败,请刷新重试")
                        return
                    }


                    
                    fasongtext=textsent
                    jxspmyDiv.innerHTML = "点击解析"
                    //fasong(textsent)
                    // 如果元素存在则执行相应的命令
                    console.log("元素已经存在!");
                    clearInterval(intervalId); // 清除定时器
                    // 这里写入你想要执行的命令或者其他操作
                } else {
                    console.log("元素还不存在...");
                }
                i++
                if (i > 20) {
                    jxspmyDiv.innerHTML = "解析失败"
                    alert("准备失败,请刷新重试")
                }
            }, 1000);
        }
        else {

            var div = document.getElementsByClassName("navigation_button")[0]; // 获取第一个符合条件的元素

            if (div != null) {
                // 元素存在
            } else {
                alert("请先登录-p")
                return
            }

            var intervalId = setInterval(function () {
                // 获取需要判断的元素
                let info = document.getElementsByClassName('preview-title')[0]
                let videoInfo = info.getElementsByClassName('video-div')[0]


                if (videoInfo) {
                    textsent = info.innerText + "***" + textsent
                    console.log(textsent);
                    if (textsent.indexOf("IV=") === -1 || textsent.indexOf("包含") === -1|| textsent.indexOf("[--秒]") > -1) {
                        jxspmyDiv.innerHTML = "解析失败"
                        alert("准备失败,请刷新重试")
                        return
                    }
                    fasongtext=textsent
                    jxspmyDiv.innerHTML = "点击解析"
                    //fasong(textsent)
                    // 如果元素存在则执行相应的命令
                    console.log("元素已经存在!");
                    clearInterval(intervalId); // 清除定时器
                    // 这里写入你想要执行的命令或者其他操作
                } else {
                    console.log("元素还不存在...");
                }
                i++
                if (i > 20) {
                    jxspmyDiv.innerHTML = "解析失败"
                    alert("准备失败,请刷新重试")
                }
            }, 1000);




        }


    }

    class BaseClass{
 
        constructor(){
    
            if(GM_getValue('iconPositionSetPage') != 0){
                /*cookie存储
                iconVipTop = this.getCookie('iconTop')?this.getCookie('iconTop'):iconVipTop;
    
                iconVipPosition = this.getCookie('iconPosition')?this.getCookie('iconPosition'):iconVipPosition;
    
                selectedLeft = iconVipPosition=='left'?'selected':'';
    
                selectedRight = iconVipPosition=='right'?'selected':'';
    
                iconVipWidth = this.getCookie('iconWidth')?this.getCookie('iconWidth'):iconVipWidth;
                */
    
                iconVipTop = GM_getValue('iconTop') || GM_getValue('iconTop') == 0?GM_getValue('iconTop'):iconVipTop;
    
                iconVipPosition = GM_getValue('iconPosition')?GM_getValue('iconPosition'):iconVipPosition;
    
                selectedLeft = iconVipPosition=='left'?'selected':'';
    
                selectedRight = iconVipPosition=='right'?'selected':'';
    
                iconVipWidth = GM_getValue('iconWidth')?GM_getValue('iconWidth'):iconVipWidth;
    
                iconWaitTime = GM_getValue('iconWaitTime')?GM_getValue('iconWaitTime')*1000:iconWaitTime;
    
                iconVipOpacity = GM_getValue('iconOpacity') || GM_getValue('iconOpacity') == 0?GM_getValue('iconOpacity'):iconVipOpacity;
    
            }
    
            GM_registerMenuCommand("设置", () => this.menuSet());
    
            this.setStyle();
        }
    
        setStyle(){
            let menuSetStyle = `
                    .zhmMask{
                        z-index:999999999;
                        background-color:#000;
                        position: fixed;top: 0;right: 0;bottom: 0;left: 0;
                        opacity:0.8;
                    }
                    .wrap-box{
                        z-index:1000000000;
                        position:fixed;;top: 50%;left: 50%;transform: translate(-50%, -200px);
                        width: 300px;
                        color: #555;
                        background-color: #fff;
                        border-radius: 5px;
                        overflow:hidden;
                        font:16px numFont,PingFangSC-Regular,Tahoma,Microsoft Yahei,sans-serif !important;
                        font-weight:400 !important;
                    }
                    .setWrapHead{
                        background-color:#f24443;height:40px;color:#fff;text-align:center;line-height:40px;
                    }
                    .setWrapLi{
                        margin:0px;padding:0px;
                    }
                    .setWrapLi li{
                        background-color: #fff;
                        border-bottom:1px solid #eee;
                        margin:0px !important;
                        padding:12px 20px;
                        display: flex;
                        justify-content: space-between;align-items: center;
                        list-style: none;
                    }
    
                    .setWrapLiContent{
                        display: flex;justify-content: space-between;align-items: center;
                    }
                    .setWrapSave{
                        position:absolute;top:-2px;right:10px;font-size:24px;cursor:pointer
                    }
                    .iconSetFoot{
                        position:absolute;bottom:0px;padding:10px 20px;width:100%;
                    z-index:1000000009;background:#fef9ef;
                    }
                    .iconSetFootLi{
                        margin:0px;padding:0px;
                    }
    
                    .iconSetFootLi li{
                        display: inline-flex;
                        padding:0px 2px;
                        justify-content: space-between;align-items: center;
                        font-size: 12px;
                    }
                    .iconSetFootLi li a{
                        color:#555;
                    }
                    .iconSetFootLi a:hover {
                        color:#fe6d73;
                    }
                    .iconSetPage{
                        z-index:1000000001;
                        position:absolute;top:0px;left:300px;
                        background:#fff;
                        width:300px;
                        height:100%;
                    }
                    .iconSetUlHead{
                    padding:0px;
                    margin:0px;
                    }
                    .iconSetPageHead{
                        border-bottom:1px solid #ccc;
                        height:40px;
                        line-height:40px;
                        display: flex;
                        justify-content: space-between;
                        align-items: center;
                        background-color:#fe6d73;
                        color:#fff;
                        font-size: 15px;
                    }
                    .iconSetPageLi{
                        margin:0px;padding:0px;
                    }
                    .iconSetPageLi li{
                        list-style: none;
                        padding:8px 20px;
                        border-bottom:1px solid #eee;
                    }
                    .zhihuSetPage{
                        z-index:1000000002;position:absolute;top:0px;left:300px;background:#fff;width:300px;height:100%;
                    }
                    .iconSetPageInput{
                        display: flex !important;justify-content: space-between;align-items: center;
                    }
                    .zhihuSetPageLi{
                        margin:0px;padding:0px;
                        height:258px;
                        overflow-y: scroll;
                    }
    
                    .zhihuSetPageContent{
                        display: flex !important;justify-content: space-between;align-items: center;
                    }
    
                    .zhm_circular{
                        width: 40px;height: 20px;border-radius: 16px;transition: .3s;cursor: pointer;box-shadow: 0 0 3px #999 inset;
                    }
                    .round-button{
                        width: 20px;height: 20px;;border-radius: 50%;box-shadow: 0 1px 5px rgba(0,0,0,.5);transition: .3s;position: relative;
                    }
                    .zhm_back{
                        border: solid #FFF; border-width: 0 3px 3px 0; display: inline-block; padding: 3px;transform: rotate(135deg);  -webkit-transform: rotate(135deg);margin-left:10px;cursor:pointer;
                    }
                    .to-right{
                        margin-left:20px; display: inline-block; padding: 3px;transform: rotate(-45deg); -webkit-transform: rotate(-45deg);cursor:pointer;
    
                    }
                    .iconSetSave{
                        font-size:24px;cursor:pointer;margin-right:5px;margin-bottom:4px;color:#FFF;
                    }
                    .zhm_set_page{
                        z-index:1000000003;
                        position:absolute;
                        top:0px;left:300px;
                        background:#fff;
                        width:300px;
                        height:100%;
                    }
                    .zhm_set_page_header{
                        border-bottom:1px solid #ccc;
                        height:40px;
                        line-height:40px;
                        display: flex;
                        justify-content: space-between;
                        align-items: center;
                        background-color:#fe6d73;
                        color:#fff;
                        font-size: 15px;
                    }
                    .zhm_set_page_content{
                        display: flex !important;justify-content: space-between;align-items: center;
                    }
                    .zhm_set_page_list{
                        margin:0px;padding:0px;
                        height: 220px;
                        overflow-y: scroll;
                    }
    
                    .zhm_set_page_list::-webkit-scrollbar {
                        /*滚动条整体样式*/
                        width : 0px;  /*高宽分别对应横竖滚动条的尺寸*/
                        height: 1px;
                    }
                    .zhm_set_page_list::-webkit-scrollbar-thumb {
                        /*滚动条里面小方块*/
                        border-radius   : 2px;
                        background-color: #fe6d73;
                    }
                    .zhm_set_page_list::-webkit-scrollbar-track {
                        /*滚动条里面轨道*/
                        box-shadow   : inset 0 0 5px rgba(0, 0, 0, 0.2);
                        background   : #ededed;
                        border-radius: 10px;
                    }
                    .zhm_set_page_list li{
                        /*border-bottom:1px solid #ccc;*/
                        padding:12px 20px;
                        display:block;
                        border-bottom:1px solid #eee;
                    }
                    li:last-child{
                        border-bottom:none;
                    }
                    .zhm_scroll{
                    overflow-y: scroll !important;
                    }
                    .zhm_scroll::-webkit-scrollbar {
                        /*滚动条整体样式*/
                        width : 0px;  /*高宽分别对应横竖滚动条的尺寸*/
                        height: 1px;
                    }
                    .zhm_scroll::-webkit-scrollbar-thumb {
                        /*滚动条里面小方块*/
                        border-radius   : 2px;
                        background-color: #fe6d73;
                    }
                    .zhm_scroll::-webkit-scrollbar-track {
                        /*滚动条里面轨道*/
                        box-shadow   : inset 0 0 5px rgba(0, 0, 0, 0.2);
                        background   : #ededed;
                        border-radius: 10px;
                    }
                    /*-form-*/
                    :root {
                        --base-color: #434a56;
                        --white-color-primary: #f7f8f8;
                        --white-color-secondary: #fefefe;
                        --gray-color-primary: #c2c2c2;
                        --gray-color-secondary: #c2c2c2;
                        --gray-color-tertiary: #676f79;
                        --active-color: #227c9d;
                        --valid-color: #c2c2c2;
                        --invalid-color: #f72f47;
                        --invalid-icon: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%20%3Cpath%20d%3D%22M13.41%2012l4.3-4.29a1%201%200%201%200-1.42-1.42L12%2010.59l-4.29-4.3a1%201%200%200%200-1.42%201.42l4.3%204.29-4.3%204.29a1%201%200%200%200%200%201.42%201%201%200%200%200%201.42%200l4.29-4.3%204.29%204.3a1%201%200%200%200%201.42%200%201%201%200%200%200%200-1.42z%22%20fill%3D%22%23f72f47%22%20%2F%3E%3C%2Fsvg%3E");
                    }
                    .text-input {
                        font-size: 16px;
                        position: relative;
                        right:0px;
                        z-index: 0;
                    }
                    .text-input__body {
                        -webkit-appearance: none;
                        -moz-appearance: none;
                        appearance: none;
                        background-color: transparent;
                        border: 1px solid var(--gray-color-primary);
                        border-radius: 3px;
                        height: 1.7em;
                        line-height: 1.7;
                        overflow: hidden;
                        padding: 2px 1em;
                        text-overflow: ellipsis;
                        transition: background-color 0.3s;
                        width:55%;
                        font-size:14px;
                        box-sizing: initial;
                    }
                    .text-input__body:-ms-input-placeholder {
                        color: var(--gray-color-secondary);
                    }
                    .text-input__body::-moz-placeholder {
                        color: var(--gray-color-secondary);
                    }
                    .text-input__body::placeholder {
                        color: var(--gray-color-secondary);
                    }
    
                    .text-input__body[data-is-valid] {
                        padding-right: 1em;
    
                    }
                    .text-input__body[data-is-valid=true] {
                        border-color: var(--valid-color);
                    }
                    .text-input__body[data-is-valid=false] {
                        border-color: var(--invalid-color);
                        box-shadow: inset 0 0 0 1px var(--invalid-color);
                    }
                    .text-input__body:focus {
                        border-color: var(--active-color);
                        box-shadow: inset 0 0 0 1px var(--active-color);
                        outline: none;
                    }
                    .text-input__body:-webkit-autofill {
                        transition-delay: 9999s;
                        -webkit-transition-property: background-color;
                        transition-property: background-color;
                    }
                    .text-input__validator {
                        background-position: right 0.5em center;
                        background-repeat: no-repeat;
                        background-size: 1.5em;
                        display: inline-block;
                        height: 100%;
                        left: 0;
                        position: absolute;
                        top: 0;
                        width: 100%;
                        z-index: -1;
                    }
                    .text-input__body[data-is-valid=false] + .text-input__validator {
                        background-image: var(--invalid-icon);
                    }
                    .select-box {
                        box-sizing: inherit;
                        font-size: 16px;
                        position: relative;
                        transition: background-color 0.5s ease-out;
                        width:90px;
                    }
                    .select-box::after {
                        border-color: var(--gray-color-secondary) transparent transparent transparent;
                        border-style: solid;
                        border-width: 6px 4px 0;
                        bottom: 0;
                        content: "";
                        display: inline-block;
                        height: 0;
                        margin: auto 0;
                        pointer-events: none;
                        position: absolute;
                        right: -72px;
                        top: 0;
                        width: 0;
                        z-index: 1;
                    }
                    .select-box__body {
                        box-sizing: initial;
                        -webkit-appearance: none;
                        -moz-appearance: none;
                        appearance: none;
                        background-color: transparent;
                        border: 1px solid var(--gray-color-primary);
                        border-radius: 3px;
                        cursor: pointer;
                        height: 1.7em;
                        line-height: 1.7;
                        padding-left: 1em;
                        padding-right: calc(1em + 16px);
                        width: 140%;
                        font-size:14px;
                        padding-top:2px;
                        padding-bottom:2px;
                    }
                    .select-box__body[data-is-valid=true] {
                        border-color: var(--valid-color);
                        box-shadow: inset 0 0 0 1px var(--valid-color);
                    }
                    .select-box__body[data-is-valid=false] {
                        border-color: var(--invalid-color);
                        box-shadow: inset 0 0 0 1px var(--invalid-color);
                    }
                    .select-box__body.focus-visible {
                        border-color: var(--active-color);
                        box-shadow: inset 0 0 0 1px var(--active-color);
                        outline: none;
                    }
                    .select-box__body:-webkit-autofill {
                        transition-delay: 9999s;
                        -webkit-transition-property: background-color;
                        transition-property: background-color;
                    }
                    .textarea__body {
                        -webkit-appearance: none;
                        -moz-appearance: none;
                        appearance: none;
                        background-color: transparent;
                        border: 1px solid var(--gray-color-primary);
                        border-radius: 0;
                        box-sizing: initial;
                        font: inherit;
                        left: 0;
                        letter-spacing: inherit;
                        overflow: hidden;
                        padding: 1em;
                        position: absolute;
                        resize: none;
                        top: 0;
                        transition: background-color 0.5s ease-out;
                        width: 100%;
                        }
                    .textarea__body:only-child {
                        position: relative;
                        resize: vertical;
                    }
                    .textarea__body:focus {
                        border-color: var(--active-color);
                        box-shadow: inset 0 0 0 1px var(--active-color);
                        outline: none;
                    }
                    .textarea__body[data-is-valid=true] {
                        border-color: var(--valid-color);
                        box-shadow: inset 0 0 0 1px var(--valid-color);
                    }
                    .textarea__body[data-is-valid=false] {
                        border-color: var(--invalid-color);
                        box-shadow: inset 0 0 0 1px var(--invalid-color);
                    }
    
                    .textarea ._dummy-box {
                        border: 1px solid;
                        box-sizing: border-box;
                        min-height: 240px;
                        overflow: hidden;
                        overflow-wrap: break-word;
                        padding: 1em;
                        visibility: hidden;
                        white-space: pre-wrap;
                        word-wrap: break-word;
                    }
                    .toLeftMove{
                        nimation:moveToLeft 0.5s infinite;
                        -webkit-animation:moveToLeft 0.5s infinite; /*Safari and Chrome*/
                        animation-iteration-count:1;
                        animation-fill-mode: forwards;
                    }
    
                    @keyframes moveToLeft{
                        from {left:200px;}
                        to {left:0px;}
                    }
    
                    @-webkit-keyframes moveToLeft /*Safari and Chrome*/{
                        from {left:200px;}
                        to {left:0px;}
                    }
    
                    .toRightMove{
                        nimation:moveToRight 2s infinite;
                        -webkit-animation:moveToRight 2s infinite; /*Safari and Chrome*/
                        animation-iteration-count:1;
                        animation-fill-mode: forwards;
                    }
                    @keyframes moveToRight{
                        from {left:0px;}
                        to {left:2000px;}
                    }
    
                    @-webkit-keyframes moveToRight /*Safari and Chrome*/{
                        from {left:0px;}
                        to {left:200px;}
                    }
    
                `;
    
            domStyle .appendChild(document.createTextNode(menuSetStyle));
    
            domHead.appendChild(domStyle);
        }
    
        menuSet(){
    
            var _this = this;
    
            var setListJson= [
                {'listName':lang.iconPosition,'setListID':'iconPositionSetPage','setPageID':'movieIconSetPage','takePlace':'0px'},
                {'listName':lang.playVideo,'setListID':'movieList','setPageID':'movieVideoSetPage','takePlace':'0px'},
            ];
    
            var zhihuOptionJson = [
                {'optionName':lang.zhVideoClose,'optionID':'removeVideo','default':'0'},
                {'optionName':lang.zhVideoDownload,'optionID':'downloadVideo','default':'22'},
                {'optionName':lang.zhADClose,'optionID':'removeAD','default':'22'},
                {'optionName':lang.zhCloseLeft,'optionID':'removeRight','default':'0'},
                {'optionName':lang.zhChangeLink,'optionID':'changeLink','default':'22'},
                {'optionName':lang.specialColumn,'optionID':'specialColumn','default':22},
                {'optionName':lang.videoTitle,'optionID':'videoTitle','default':22},
                {'optionName':lang.zhKeywordClose,'optionID':'removeKeyword','default':'0'},
                {'optionName':lang.authorNameClose,'optionID':'removeAuthorName','default':22},
                {'optionName':lang.yanxuanClose,'optionID':'removeYanxuan','default':'0'}
            ];
    
            var playVideoOptionJson ={
                'optionName':lang.playVideoLineAdd,
                'optionID':'videoPlayLineAdd',
                'default':videoPlayLineAdd,
                'textarea':'videoPlayLineAddTextarea',
                'textareaId':'playVideoLineTextarea',
                'tip':
    `纯净1,https://im1907.top/?jx=
    B站1,https://jx.jsonplayer.com/player/?url=
    爱豆,https://jx.aidouer.net/?url=
    BL,https://vip.bljiex.com/?v=
    冰豆,https://bd.jx.cn/?url=
    CK,https://www.ckplayer.vip/jiexi/?url=
    H8,https://www.h8jx.com/jiexi.php?url=
    JY,https://jx.playerjy.com/?url=
    解析la,https://api.jiexi.la/?url=
    M3U8,https://jx.m3u8.tv/jiexi/?url=
    PM,https://www.playm3u8.cn/jiexi.php?url=
    盘古,https://www.pangujiexi.cc/jiexi.php?url=
    七哥,https://jx.nnxv.cn/tv.php?url=
    听乐,https://jx.dj6u.com/?url=
    维多,https://jx.ivito.cn/?url=
    虾米,https://jx.xmflv.com/?url=
    YT,https://jx.yangtu.top/?url=
    夜幕,https://www.yemu.xyz/?url=
    云析,https://jx.yparse.com/index.php?url=
    17云,https://www.1717yun.com/jx/ty.php?url=
    180,https://jx.000180.top/jx/?url=
    4K,https://jx.4kdv.com/?url=
    8090,https://www.8090g.cn/?url=`,
    
                 'valueName':'playVideoLineText'}
    
            var setHtml = "<div id='setMask' class='zhmMask'></div>";
    
            setHtml +="<div class='wrap-box' id='setWrap'>";
    
            setHtml +="<div class='iconSetPage' id='movieIconSetPage'>";
    
            setHtml +="<ul class='iconSetUlHead'><li class='iconSetPageHead'><span class='zhm_back'></span><span>"+lang.iconPosition+"</span><span class='iconSetSave'>×</span></li></ul>";
    
            setHtml +="<ul class='iconSetPageLi'>";
    
            setHtml +="<li>"+lang.iconHeight+":<span class='text-input'><input class='text-input__body' id='iconTop' value='"+iconVipTop+"' placeholder='"+lang.tipIconHeight+"'><span class='text-input__validator'></span></span></li>";
    
            setHtml += "<li  style='display: inline-flex;'><span style='padding-top:4px;'>"+lang.iconLine+":</span><div class='select-box'><select class='select-box__body' id='iconPosition'>";
    
            setHtml +="<option value='left' "+selectedLeft+">"+lang.iconLeft+"</option><option value='right' "+selectedRight+">"+lang.iconRight+"</option>";
    
            setHtml +="</select></div></li>"
    
            setHtml +="<li>"+lang.iconWidth+":<span class='text-input'><input class='text-input__body' id='iconWidth' value='"+iconVipWidth+"' placeholder='"+lang.tipIconWidth+"'><span class='text-input__validator'></span></span></li>";
    
            setHtml += "<li  style='display: inline-flex;'><span style='padding-top:4px;'>"+lang.iconWaitTime+":</span><div class='select-box'><select class='select-box__body' id='iconWaitTime'>";
    
            for(let i =1;i<=8;i++){
    
                let iconSelected = GM_getValue('iconWaitTime')==i/2?'selected':'';
    
                setHtml +="<option value="+i/2+" "+iconSelected+">"+i/2+"秒</option>";
    
            }
    
            setHtml +="</select></div></li>";
    
            setHtml +="<li>透 明 度 :<span class='text-input'><input class='text-input__body' id='iconOpacity' value='"+iconVipOpacity+"' placeholder='"+lang.tipIconOpacity+"'></span></li>";
    
            setHtml +="</ul></div>";
    
            setHtml +="<div class='zhm_set_page' id='movieVideoSetPage'>";
    
            setHtml +="<ul class='iconSetUlHead'><li class='zhm_set_page_header'><span class='zhm_back'></span><span>"+lang.setPlayVideo+"</span><span  class='iconSetSave'>×</li></ul>";
    
            setHtml +="<ul class='zhm_set_page_list' style='overflow-y:unset'>";
    
            let backColor,switchBackCorlor,display;
    
            let optionValue = GM_getValue(playVideoOptionJson.optionID,playVideoOptionJson.default);
    
            if(optionValue != '22'){
    
                backColor = '#fff';
    
                switchBackCorlor = '#FFF';
    
            }else{
    
                backColor = '#fe6d73';
    
                switchBackCorlor = '#FFE5E5';
    
            }
    
            setHtml +="<li>";
    
            setHtml +="<div class='zhm_set_page_content'>";
    
            setHtml += "<span class='playVideoOptionName'>"+playVideoOptionJson.optionName+"</span>";
    
            setHtml +="<div class='zhm_circular' style='background-color:"+switchBackCorlor+"' id='"+playVideoOptionJson.optionID+"'>";
    
            setHtml +="<div class='round-button' style='background: "+backColor+"; left: "+optionValue+"px;'></div>";
    
            setHtml += "</div></div>";
    
            setHtml+="</li><li>";
    
            setHtml +="<div>解析线路</div>";
    
            setHtml +="<div class='form__textarea'>";
    
            setHtml +="<div class='textarea js-flexible-textarea' style='padding: 5px 0px;' id='"+playVideoOptionJson.textarea+"'>";
    
            setHtml +="<textarea rows='9' class='textarea__body zhm_scroll' placeholder='"+lang.tipPlayVideoLineAdd+"' style='width:250px;font-size:12px;padding:4px;resize:none;' id='"+playVideoOptionJson.textareaId+"'>"+GM_getValue(playVideoOptionJson.valueName,playVideoOptionJson.tip)+"</textarea>";
    
            setHtml +="</div></div></li>";
    
            setHtml +="</ul>"
    
            setHtml +="</div>"
    
            setHtml +="<ul class='iconSetUlHead'><li class='iconSetPageHead'><span></span><span>"+lang.set+"</span><span class='iconSetSave'>×</span></li></ul>";
    
            setHtml +="<ul class='setWrapLi'>";
    
            for(var setN=0;setN<setListJson.length;setN++){
    
                var listValue = GM_getValue(setListJson[setN].setListID,'22');
    
                let backColor,arrowColor,switchBackCorlor;
    
                if(listValue != 22){
                    backColor = '#fff';
                    arrowColor= '#EEE';
                    switchBackCorlor = '#FFF';
    
                }else{
                    backColor = '#fe6d73';
                    arrowColor = '#CCC';
                    switchBackCorlor = '#FFE5E5';
                }
    
                if(setListJson[setN].setPageID == ''){
                    arrowColor = '#EEE';
                };
                setHtml +="<li><span>"+setListJson[setN].listName+"</span>";
    
                setHtml +="<div class='setWrapLiContent'>";
    
                setHtml +="<div class='zhm_circular' id='"+setListJson[setN].setListID+"' style='background-color: "+switchBackCorlor+";'><div class='round-button' style='background: "+backColor+";left: "+listValue+"px'></div></div>";
    
                setHtml +="<span class='to-right' data='"+setListJson[setN].setPageID+"' takePlace='"+setListJson[setN].takePlace+"' style='border: solid "+arrowColor+"; border-width: 0 3px 3px 0;'></span></div></li>";
            }
    
            setHtml +="</ul>";
    
            setHtml +="<div style='height:40px;' id='zhmTakePlace'></div>";
    
            setHtml +="<div class='iconSetFoot' style=''>";
    
            setHtml +="<ul class='iconSetFootLi'>";
    
            setHtml +="<li><a href='https://gitlab.com/lanhaha/lanrenjiaoben#%E5%AE%89%E8%A3%85tm' target='_blank'>"+lang.scriptsinstall+"</a></li>・<li><a href='https://gitlab.com/lanhaha/lanrenjiaoben#%E4%BD%BF%E7%94%A8' target='_blank'>"+lang.scriptsuse+"</a></li>・<li><a href='https://gitlab.com/lanhaha/lanrenjiaoben#%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98' target='_blank'>"+lang.question+"</a></li>・<li><a href='https://t.me/+sGo6ZZvy54wzYTll' target='_blank'>"+lang.tggroup+"</a></li>";
    
            setHtml +='</ul>';
    
            setHtml +='</div>';
    
            setHtml += "</div>";
    
            if(document.querySelector('#setMask')) return;
    
            this.createElement('div','zhmMenu');
    
            let zhmMenu = document.getElementById('zhmMenu');
    
            zhmMenu.innerHTML = setHtml;
    
            let timerZhmIcon = setInterval(function(){
    
                if (document.querySelector('#zhmMenu')){
    
                    clearInterval(timerZhmIcon); // 取消定时器
    
                    let circular = document.querySelectorAll('.zhm_circular');
    
                    circular.forEach(function(item){
    
                        item.addEventListener('click', function(_e){
    
                            let buttonStyle = item.children[0].style;
    
                            let left = buttonStyle.left;
    
                            left = parseInt(left);
    
                            let listLeftValue;
    
                            if(left==0){
    
                                buttonStyle.left = '22px';
    
                                buttonStyle.background = '#fe6d73';
    
                                item.style.background='#ffE5E5';
    
                                if(item.nextSibling && item.nextSibling.getAttribute('data')){
    
                                    item.nextSibling.setAttribute('style','border: solid #ccc;border-width: 0 3px 3px 0;')
                                }
    
                                listLeftValue = 22;
    
                            }else{
    
                                buttonStyle.left = '0px';
    
                                buttonStyle.background = '#fff';
    
                                item.style.background='#fff';
    
                                if(item.nextSibling){
    
                                    item.nextSibling.setAttribute('style','border: solid #EEE;border-width: 0 3px 3px 0;')
    
                                }
    
                                listLeftValue = 0;
                            }
    
                            let setListID = item.id;
    
                            GM_setValue(setListID,listLeftValue);
    
                        })
    
                    });
    
                    let toRight = document.querySelectorAll('.to-right');
    
                    toRight.forEach(function(item){
    
                        item.addEventListener('click', function(e){
    
                            let left = item.previousSibling.children[0].style.left;
    
                            left = parseInt(left);
    
                            if(left != 22) return;
    
                            let setPageID = item.getAttribute('data');
    
                            let pageId = document.getElementById(setPageID);
    
                            pageId.className='iconSetPage toLeftMove';
    
                            //实时图标高度
                            if(setPageID == 'movieIconSetPage'){
    
                                document.querySelector('#iconTop').value=document.querySelector("#zhmlogo").offsetTop;
    
                                document.querySelector('#zhmTakePlace').style="height:200px";
    
    
                            }
    
                            if(setPageID == 'movieVideoSetPage'){
    
                                document.querySelector('#zhmTakePlace').style="height:200px";
                            }
    
                            console.log(setPageID);
    
                        })
    
                    })
    
                    let toBack = document.querySelectorAll('.zhm_back');
    
                    toBack.forEach(function(item){
    
                        item.addEventListener('click', function(e){
    
                            let parentDom = item.parentNode.parentNode.parentNode;
    
                            parentDom.className='iconSetPage toRightMove';
    
                            document.querySelector('#zhmTakePlace').style='height:40px;'
    
                        })
    
                    })
    
                    let setSave = document.querySelectorAll('.iconSetSave');
    
                    setSave.forEach(function(item){
    
                        item.addEventListener('click',()=>{
    
                            let iconTop = document.getElementById('iconTop').value;
    
                            let iconOpacity=document.getElementById('iconOpacity').value;
    
                            let iconPosition = document.getElementById('iconPosition').value;
    
                            let iconWidth = document.getElementById('iconWidth').value;
    
                            let iconWaitTime = document.getElementById('iconWaitTime').value;
    
                            let playVideoLineText = document.querySelector('#playVideoLineTextarea').value;
    
                            let playVideoLineLeft = document.querySelector('#videoPlayLineAdd').children[0].style.left;
    
                            if(iconTop != ''){
    
                                if(!(/(^[0-9][0-9]{0,2}$)/.test(iconTop))){
    
                                    alert(lang.tipErrorIconHeight);
    
                                    return false;
                                }
    
                                //_this.setCookie('iconTop',iconTop,30);
    
                                GM_setValue('iconTop',iconTop);
                            }
    
                            if(iconOpacity != ''){
    
                                if(!(/^(?:0|[1-9][0-9]?|100)$/.test(iconOpacity))){
    
                                    alert(lang.tipErrorIconOpacity);
    
                                    return false;
                                }
    
                                //_this.setCookie('iconTop',iconTop,30);
                                //alert(iconOpacity);return;
                                GM_setValue('iconOpacity',iconOpacity);
                            }
    
                            if(iconPosition != ''){
    
                                //_this.setCookie('iconPosition',iconPosition,30);
    
                                GM_setValue('iconPosition',iconPosition);
                            }
    
                            if(iconWaitTime != ''){
    
                                GM_setValue('iconWaitTime',iconWaitTime);
                            }
    
                            if(iconWidth !=''){
    
                                if(!(/(^([1-9][0-9]?)$)/.test(iconWidth))){
    
                                    alert(lang.tipErrorIconWidth);
    
                                    return false;
                                }
    
                                //_this.setCookie('iconWidth',iconWidth,30);
    
                                GM_setValue('iconWidth',iconWidth);
                            }
    
                            if(GM_getValue('videoPlayLineAdd') == 22){
    
                                if(playVideoLineText){
    
                                    let lineObj = _this.getLine(playVideoLineText);
    
                                    if(lineObj.length>0){
    
                                        GM_setValue('playVideoLineText',playVideoLineText);
    
                                    }else{
                                        alert('线路输入不正确');
                                        return;
                                    }
    
                                }else{
    
                                    GM_setValue('playVideoLineText','');
                                }
    
                            }else{
    
                                GM_setValue('playVideoLineText',playVideoLineText);
                            }
    
                            history.go(0);
                        })
                    })
    
                    document.getElementById('iconTop').addEventListener('change',function(){
    
                        let iconTop = this.value;
    
                        if(!(/(^[1-9]\d*$)/.test(iconTop))){
    
                            this.setAttribute('data-is-valid','false')
    
    
                        }else{
    
                            this.setAttribute('data-is-valid','true')
                        }
    
                        return false;
    
                    })
    
                    document.getElementById('iconWidth').addEventListener('change',function(){
    
                        let iconWidth = this.value;
    
                        if(!(/(^[1-9]\d*$)/.test(iconWidth))){
    
                            this.setAttribute('data-is-valid','false')
    
    
                        }else{
    
                            this.setAttribute('data-is-valid','true')
                        }
    
                        return false;
    
                    })
                    //腾讯视频快捷键冲突
                    if(couponUrl.match(/v\.qq\.com\/x\/cover/)){
    
                        let addLineText =document.querySelector('#playVideoLineTextarea');
    
                        addLineText.addEventListener('keydown',function(e){
    
                            let startPos = addLineText.selectionStart;
    
                            let endPos = addLineText.selectionEnd;
    
                            if (startPos === undefined || endPos === undefined) return;
    
                            keyCode.forEach(function(item){
    
                                if(e.keyCode == item.code && e.shiftKey==item.isShift){
    
                                    let textValue = addLineText.value;
    
                                    let startValue = textValue.substring(0,startPos);
    
                                    let endValue = textValue.substring(startPos);
    
                                    let allValue = startValue+item.value+endValue;
    
                                    addLineText.value=allValue;
    
                                    addLineText.selectionStart = startPos+1;
    
                                    addLineText.selectionEnd = endPos+1;
    
                                }
                            })
    
                        })
                    }
                }
    
            })
    
            }
    
        createElement(dom,domId){
    
            var rootElement = document.body;
    
            var newElement = document.createElement(dom);
    
            newElement.id = domId;
    
            var newElementHtmlContent = document.createTextNode('');
    
            rootElement.appendChild(newElement);
    
            newElement.appendChild(newElementHtmlContent);
    
        }
    
        request(method,url,data,isCookie=''){
    
            let request = new XMLHttpRequest();
    
            return new Promise((resolve,reject)=>{
    
                request.onreadystatechange=function(){
    
                    if(request.readyState==4){
    
                        if(request.status==200){
    
                            resolve(request.responseText);
    
                        }else{
    
                            reject(request.status);
                        }
    
                    }
                }
    
                request.open(method,url);
                //request.withCredentials = true;
                if(isCookie){
                    request.withCredentials = true;
                }
                request.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
                request.send(data);
    
            })
    
        }
    
        setCookie(cname,cvalue,exdays){
    
            var d = new Date();
    
            d.setTime(d.getTime()+(exdays*24*60*60*1000));
    
            var expires = "expires="+d.toGMTString();
    
            document.cookie = cname+"="+cvalue+"; "+expires;
        }
    
        getCookie(cname){
            var name = cname + "=";
            var ca = document.cookie.split(';');
            for(var i=0; i<ca.length; i++) {
                var c = ca[i].trim();
                if (c.indexOf(name)==0) { return c.substring(name.length,c.length); }
            }
            return "";
        }
    
        getQueryString(e) {
            var t = new RegExp("(^|&)" + e + "=([^&]*)(&|$)");
            var a = window.location.search.substr(1).match(t);
            if (a != null) return a[2];
            return "";
        }
    
        getUrlParams(url){
            let reg = /([^?&+#]+)=([^?&+#]+)/g;
            let obj={};
            url.replace(reg,(res,$1,$2)=>{obj[$1]=$2});
            return obj;
        }
    
        getLine(text){
    
            let textArr = text.split('\n');
    
            if(textArr.length > 0){
    
                let lineObj = [];
    
                let match = /^(.+)(https?:\/\/.+)$/;
    
                textArr.forEach(function(item){
    
                    item = item.replace(/\s*,*/g,'');
    
                    if(!item) return true;
    
                    let lineMatch = item.match(match);
    
                    if(lineMatch){
    
                        lineObj.push({'name':lineMatch[1].substring(0,4),'url':lineMatch[2]});
    
                    }else{
    
                        lineObj=[];
    
                        return false;
                    }
    
                })
                return lineObj;
    
            }
        }
        //all参数默认空,是真时返回为数组
        static getElement(css,all=''){
    
            return new Promise((resolve,reject)=>{
    
                let num = 0;
    
                let timer = setInterval(function(){
    
                    num++
    
                    let dom;
    
                    if(all == false){
    
                        dom = document.querySelector(css);
    
                        if(dom){
    
                            clearInterval(timer);
    
                            resolve(dom);
    
                        }
    
                    }else{
    
                        dom = document.querySelectorAll(css);
    
                        if(dom.length>0){
    
                            clearInterval(timer);
    
                            resolve(dom);
    
                        }
                    }
    
                    if(num==20){
                        clearInterval(timer);
                        resolve(false);
                    }
    
                },300)
    
                })
    
    
        }
    
        static toast(msg,duration){
    
            duration=isNaN(duration)?3000:duration;
    
            let toastDom = document.createElement('div');
    
            toastDom.innerHTML = msg;
    
            //toastDom.style.cssText="width: 60%;min-width: 150px;opacity: 0.7;height: 30px;color: rgb(255, 255, 255);line-height: 30px;text-align: center;border-radius: 5px;position: fixed;top: 40%;left: 20%;z-index: 999999;background: rgb(0, 0, 0);font-size: 12px;";
            toastDom.style.cssText='padding:2px 15px;min-height: 36px;line-height: 36px;text-align: center;transform: translate(-50%);border-radius: 4px;color: rgb(255, 255, 255);position: fixed;top: 50%;left: 50%;z-index: 9999999;background: rgb(0, 0, 0);font-size: 16px;'
    
            document.body.appendChild(toastDom);
    
            setTimeout(function() {
    
                var d = 0.5;
    
                toastDom.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in';
    
                toastDom.style.opacity = '0';
    
                setTimeout(function() { document.body.removeChild(toastDom) }, d * 1000);
    
            }, duration);
    
        }
        //create zhmLogoIcon
        zhmLogo(){
    
           var _this = this;
    
           let sortDiv = iconVipPosition=='left'?'row':'row-reverse';
    
           let playVideoStyle = `
           .zhm_play_vidoe_icon{
              padding-top:2px;
              cursor:pointer;
              z-index:999999;
              position:fixed;${iconVipPosition}:5px;top:${iconVipTop}px;
              text-align:center;
              overflow:visible;
              display:flex;
              flex-direction:${sortDiv};
              width:auto;
           }
           .zhm_play_video_wrap{
              z-index:9999999;
              overflow: hidden;
              width:300px;
           }
           .iconLogo{
           opacity:${iconVipOpacity/100};
           }
           .zhm_play_video_line{
              width:320px;
              height:316px;
              overflow-y:scroll;
              overflow-x:hidden;
           }
           .zhm_play_vide_line_ul{
              width:300px;
              display: flex;
              justify-content: flex-start;
              flex-flow: row wrap;
              list-style: none;
              padding:0px;
              margin:0px;
    
           }
           .zhm_play_video_line_ul_li{
              padding:4px 0px;
              margin:2px;
              width:30%;
              color:#FFF;
              text-align:center;
              background-color:#f24443;
              box-shadow:0px 0px 10px #fff;
              font-size:14px;
           }
           .zhm_play_video_line_ul_li:hover{
              color:#260033;
              background-color:#fcc0c0
           }
           .zhm_line_selected{
              color:#260033;
              background-color:#fcc0c0
           }
    
           .zhm_play_video_jx{
              width:100%;
              height:100%;
              z-index:999999;
              position: absolute;top:0px;padding:0px;
           }
           `;
    
            domStyle .appendChild(document.createTextNode(playVideoStyle));
    
            domHead.appendChild(domStyle);
    
            let playWrapHtml = "<div href='javascript:void(0)' target='_blank' style='' class='playButton zhm_play_vidoe_icon' id='zhmlogo'>";
    
            playWrapHtml += "<img class='iconLogo' style='width:"+iconVipWidth+"px;height:"+iconVipWidth*1.5+"px' src=''>"
    
            playWrapHtml += "<div>";
    
            _this.createElement('div','zhmIcon');
    
            let zhmPlay = document.getElementById('zhmIcon');
    
            zhmPlay.innerHTML = playWrapHtml;
    
        }
        //左键按下拖动
        //type:根据不同类型,处理图标单击事务
        zhmLogoDrag(type,web){
    
            var _this = this;
    
            var zhmLogoDrag=document.querySelector("#zhmlogo");
    
            var zhmLogoIcon = document.querySelector(".iconLogo");
    
            if(!zhmLogoDrag || !zhmLogoIcon)return;
    
            zhmLogoDrag.onmousedown = function(event){
    
                if(event.which==3)return false;//屏蔽右键
    
                let sedownTop = zhmLogoDrag.offsetTop;
    
                let zhmLogoIconHeight = zhmLogoIcon.offsetHeight;
    
                let bottomSpace = 10;
    
                if(event.target.className != 'iconLogo')return;
    
                //let shiftX = event.clientX - zhmLogoDrag.getBoundingClientRect().left;
                let shiftx = 5;
    
                let shiftY = event.clientY-zhmLogoDrag.getBoundingClientRect().top;
    
                zhmLogoDrag.style.position = 'fixed';
    
                zhmLogoDrag.style.zIndex = 9999999;
    
                document.body.append(zhmLogoDrag);
    
                function onMouseMove(event){
    
                    //zhmLogoDrag.style.left = pageX - shiftX + 'px';
                    zhmLogoDrag.style.left = '5px';
    
                    let height = window.innerHeight - zhmLogoIconHeight-bottomSpace;
    
                    let y = event.pageY-shiftY;
    
                    y = Math.min(Math.max(0, y), height);
    
                    zhmLogoDrag.style.top = y+'px';
    
                }
                //在mousemove事件上移动图标
                document.addEventListener('mousemove',onMouseMove);
                //松开事件
                document.onmouseup = function(e){
    
                    GM_setValue('iconTop',zhmLogoDrag.offsetTop);
    
                    document.removeEventListener('mousemove', onMouseMove);
    
                    zhmLogoDrag.onmouseup = null;
    
                    let height = zhmLogoDrag.offsetTop+zhmLogoIconHeight+bottomSpace;
    
                    if(zhmLogoDrag.offsetTop < 0){
    
                        zhmLogoDrag.style.top ='0px';
                    }
    
                    if(window.innerHeight < height){
    
                        zhmLogoDrag.style.top =window.innerHeight-zhmLogoIconHeight-bottomSpace+'px';
    
                    }
                    //click事件处理
                    switch(type){
    
                        case 'video':
    
                            if(zhmLogoDrag.offsetTop==sedownTop && web.length == 0 && zhmLogoDrag.offsetTop>0 && window.innerHeight > height){
    
                                BaseClass.toast('请在视频播放页点击图标');
                            }
    
                            break;
                        case 'music':
    
                            if(zhmLogoDrag.offsetTop==sedownTop && e.target.className == 'iconLogo'){
    
                                //document.removeEventListener('mousemove', onMouseMove);
    
                                //zhmLogoDrag.onmouseup = null;
    
                                let musicUrlData = [
                                    {match:/^https?:\/\/music\.163\.com\/#\/(?:song|dj)\?id/},
                                    {match:/^https?:\/\/y\.music\.163\.com\/m\/(?:song|dj)\?id/},
                                    {match:/^https?:\/\/music\.163\.com\/(?:song|dj)\?id/},
                                    {match:/^https?:\/\/y\.qq\.com\/n\/ryqq\/player/},
                                    {match:/kugou\.com/},
                                    {match:/kuwo\.cn/},
                                    {match:/^https?:\/\/www\.ximalaya\.com/},
                                ]
    
                                let musicUrl = musicUrlData.filter(function(item){
    
                                    return location.href.match(item.match);
    
                                })
    
                                if(musicUrl.length==0){
    
                                    BaseClass.toast(web[0].tip);
    
                                    return;
                                }
    
                                switch(web[0].name){
                                    case 'netease':
                                        neteaseFun();
                                        break;
                                    case 'qq':
                                        qqFun();
                                        break;
                                    case 'kugou':
                                        kugouFun();
                                        break;
                                    case 'kuwo':
                                        kuwoFun();
                                        break;
                                    case 'ximalaya':
                                        ximalayaFun();
                                        break;
                                }
    
                                function neteaseFun(){
    
                                    let urlParams = _this.getUrlParams(location.href);
    
                                    if(urlParams.id == undefined) return;
    
                                    let neteaseUrlEncode = encodeURIComponent('https://music.163.com/song?id='+urlParams.id);
    
                                    //let openUrl = webUrl+'?url='+neteaseUrlEncode;
    
                                    let openUrl = webUrl+"?id="+urlParams.id+"&type=netease"
    
                                    window.open(openUrl);
    
                                }
    
                                function qqFun(){
    
                                    let qqSongMatch;
    
                                    if(document.querySelector(".player_music__info")){
    
                                        qqSongMatch = document.querySelector(".player_music__info").childNodes[0].href.match(/songDetail\/(\S*)\?/);
    
                                    }else if(document.querySelector("#sim_song_info")){
    
                                        qqSongMatch = document.querySelector("#sim_song_info").childNodes[0].href.match(/song\/(\S*).html/);
    
                                    }else{
    
                                        qqSongMatch = '';
                                    }
    
                                    if(!qqSongMatch[1]){console.log('没有获取到歌曲ID'); return};
    
                                    let audioLink = encodeURIComponent(document.querySelector("audio").src);
    
                                    let openUrl = webUrl+'?id='+qqSongMatch[1]+'&type=qq&playUrl='+audioLink;
    
                                    window.open(openUrl);
    
                                }
    
                                function kugouFun(){
    
                                    let audioModule = document.querySelector('#audioModule');
    
                                    if(audioModule){
    
                                        document.querySelector('#audioModule').style='bottom:0px;';
    
                                        document.querySelector('#showHide_playbar').className = 'icon show-playbar-btn';
    
                                    }
                                    BaseClass.toast('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"',2000)
    
                                    //alert('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"。');
    
                                    /*
    
                                    let songKugouMatch = newUrl.match(jxMusicWeb[0].match);
    
                                    let audioSrc = encodeURIComponent(document.querySelector("audio").src);
    
                                    let openUrl = webUrl+'?id='+songKugouMatch[1]+'&type=kugou&playUrl='+audioSrc;
    
                                    window.open(openUrl);
                                    */
                                }
    
                                function kuwoFun(){
    
                                    document.querySelector('.playControl').style='bottom:0px';
    
                                    BaseClass.toast('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"',2000)
    
                                    //alert('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"。');
    
                                    /*
                                    let songKuwoMatch = newUrl.match(jxMusicWeb[0].match);
    
                                    let audioSrc = encodeURIComponent(document.querySelector("audio").src);
    
                                    let openUrl = webUrl+'?id='+songKuwoMatch[1]+'&type=kuwo&playUrl='+audioSrc;
    
                                    window.open(openUrl);
                                    */
                                }
    
                                function ximalayaFun(){
    
                                    document.querySelector('.xm-player').style='bottom:0px';
    
                                    BaseClass.toast('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"',2000)
    
                                    //alert('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"。');
    
                                    /*
                                    let urlInfo = newUrl.match(jxMusicWeb[0].match);
    
                                    console.log(webUrl+'?id='+urlInfo[1]+'&type=ximalaya&playUrl='+encodeURIComponent(newUrl));
    
                                    if(urlInfo[1]){
    
                                        window.open(webUrl+'?id='+urlInfo[1]+'&type=ximalaya&playUrl='+encodeURIComponent(newUrl));
    
                                    }else{
    
                                        console.log('没有获取url参数');
                                    }
                                    */
                                }
                            }
                            break;
                        case 'youtube':
    
    
    
                            break;
    
                    }
                };
    
            };
    
            zhmLogoDrag.ondragstart = function(){
                return false;
            };
        }
        //下载
        static LR_download(url,filename){
    
            let ua = navigator.userAgent.toLowerCase();
    
            console.log(ua.match(/version\/([\d.]+).*safari/));
    
            if(ua.match(/version\/([\d.]+).*safari/)){
    
                window.open(url);
    
            }else{
    console.log(url);
                GM_download(url,filename);
            }
    
    
        }
    
    }
    function fasong(textsent) {
        runAsync("http://ip.haijiao007.asia/getnmm1", "POST", textsent).then((result) => { return result; }).then(function (result) {
            //console.log(result);
            if (result.indexOf("false") > -1 && result.indexOf("****") === -1) {
                jxspmyDiv.innerHTML = "解析失败"
                alert("解析失败,请刷新重试")
                return
            } else {
                jxspmyDiv.innerHTML = "解析成功"
                
                setTimeout(function(){
                    jxmyDiv.innerHTML = " 复制链接"
                },2000);
                
                let splittedText = result.split("****"); // 用空格分割文本
                downloadurl = splittedText[1]
                alert(splittedText[0])
                //alert("视频解析成功!\n 先感谢各位老板的打赏,用的好的话,希望各位老板多多打赏,使用人数越来越多,希望打赏可以跟上人数增长!!!我每天努力给大家更新,现在脚本已经优化很多,效果已经好多了。最后还是感谢打赏的各位老板!!!\n后续打算开放外链,可以使用idm下载,这个下载视频很快,也很方便!!\n如果脚本无效,请更新脚本!\n本脚本发布在油猴,别的途径均为倒卖!!!\n 支持油猴脚本的浏览器有猴狐浏览器(推荐)、M浏览器、via浏览器、X浏览器、雨见浏览器。不能用的话可以一个个调试过去");
                var blob = new Blob([splittedText[2]], { type: 'text/plain' });
                newurl = URL.createObjectURL(blob)
                console.log("newurl", newurl)
                //play(newurl)
                setTimeout(async () => {
                    await play(newurl)
                }, 1000)

            }




        });

    }

    function replace_exist_img(body) {
        let content = body.content;
        let attachments = body.attachments;
        let all_img = {};
        let has_video = -1;
        for (var i = 0; i < attachments.length; i++) {
            var atta = attachments[i];
            if (atta.category === 'images') {
                all_img[atta.id] = atta.remoteUrl;
            }
            if (atta.category === 'video') {
                has_video = i;
                return [body, undefined, has_video];
            }
        }
        let re_img = /<img src=\"https:\/\/[\w\.\/]+?\/images\/.*?\" data-id=\"(\d+)\".*?\/>/g;
        for (let e of content.matchAll(re_img)) {
            let id = parseInt(e[1]);
            if (id in all_img) {
                // let nsrc = all_img[id];
                // let src = new RegExp(`(<img src=\")https:\/\/[\\w\.\/]+?\/images\/.*?\(" data-id=\"${id}\".*?\/>)`, 'g');
                // content = content.replace(src, `$1${nsrc}$2`);
                delete all_img[id];
            }
        }
        body.content = content;
        return [body, all_img, has_video];
    }

    function modify_data(data) {

        let body = JSON.parse(decode(data));
        console.log(body)
        if (body.node.vipLimit != 0) {
            body = remove_vip(body);
            return jencode(body);
        }
        let [nbody, rest_img, has_video] = replace_exist_img(body);
        body = nbody;
        // 已购买的帖子
        if (body.content.includes(`[/sell]`)) {
            return jencode(body);
        }
        if ('sale' in body && body.sale !== null) {
            body.sale.is_buy = true;
            body.sale.buy_index = parseInt(Math.random() * (5000 - 1000 + 1) + 1000, 10);
        }
        if (has_video >= 0) {
            let [nbody, v] = replace_m3u8(body, has_video);
            return jencode(nbody);
        }
        let img_elements = []
        for (const [id, src] of Object.entries(rest_img)) {
            img_elements.push(`<img src="${src}" data-id="${id}"/>`);
        }
        let selled_img = `[sell]` + img_elements.join() + `[/sell]`;
        let ncontent = body.content.replace(/<span class=\"sell-btn\".*<\/span>/, selled_img);
        body.content = ncontent;
        return jencode(body);
    }

    function modify_user(data, host, id) {
        if (data.errorCode === 0) {
            return data;
        }
        data.isEncrypted = true;
        data.errorCode = 0;
        data.success = true;
        data.message = "";
        let udict = get_user_dict(host, id);
        data.data = jencode(udict)
        return data
    }


    function IsPhone() {
        var info = navigator.userAgent;

        if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent)) {
            // 手机端代码
            console.log("isPhone=" + true)
            return true;
        } else {
            // 电脑端代码
            console.log("isPhone=" + false)
            return false;
        }

        //var isPhone = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/mobile/i.test(info);

    }
    const originOpen = XMLHttpRequest.prototype.open;
    const re_topic = /\/api\/topic\/\d+/;
    const re_user = /\/api\/user\/info\/\d+/;

    XMLHttpRequest.prototype.open = function (_, url) {
        // 拦截topic
        if (re_topic.test(url)) {
            const xhr = this;
            const getter = Object.getOwnPropertyDescriptor(
                XMLHttpRequest.prototype,
                "response"
            ).get;
            Object.defineProperty(xhr, "responseText", {
                get: () => {
                    let result = getter.call(xhr);
                    try {
                        let res = JSON.parse(result, `utf-8`);
                        // 这里修改data
                        res.data = modify_data(res.data)
                        return JSON.stringify(res, `utf-8`);
                    } catch (e) {
                        console.log('发生异常! 解析失败!');
                        console.log(e);
                        return result;
                    }
                },
            });
        } else if (re_user.test(url)) {
            const xhr = this;
            const getter = Object.getOwnPropertyDescriptor(
                XMLHttpRequest.prototype,
                "response"
            ).get;
            Object.defineProperty(xhr, "responseText", {
                get: () => {
                    let result = getter.call(xhr);
                    try {
                        let res = JSON.parse(result, `utf-8`);
                        let furl = xhr.responseURL;
                        let r = furl.match(/\W*(\w+)\.com\/api\/user\/info\/(\d+)/);
                        // 这里修改data
                        let data = modify_user(res, r[1], r[2]);
                        return JSON.stringify(data, `utf-8`);
                    } catch (e) {
                        console.log('发生异常! 解析失败!');
                        console.log(e);
                        return result;
                    }
                },
            });
        }
        originOpen.apply(this, arguments);
    };

    let clicked_flag = false;

    document.addEventListener("DOMNodeInserted", function (event) {
        if (!clicked_flag) {
            for (const element of document.getElementsByClassName('el-message-box')) {
                if (element.innerText.indexOf('令牌已过期') > -1) {
                    clicked_flag = true;
                    let e = element.querySelector("div.el-message-box__header > button");
                    setTimeout((e) => { e.click(); }, 100, e);
                    break;
                }
            }
        }
        if (event.relatedNode.getAttribute('id') === 'tidio-chat') {
            var eles = document.getElementsByTagName('*');
            for (var i = 0; i < eles.length; i++) {
                eles[i].style.userSelect = 'text';
            }
        }
    }, false);

})();




(function () {
    'use strict';

    const mgmapi = {

        addStyle(s) {
            let style = document.createElement("style");
            style.innerHTML = s;
            document.documentElement.appendChild(style);
        },
        xmlHttpRequest(details) {
            return ((typeof GM_xmlhttpRequest === "function") ? GM_xmlhttpRequest : GM.xmlHttpRequest)(details);
        },



    };


    if (location.host === "tools.thatwind.com" || location.host === "localhost:3000") {
        mgmapi.addStyle("#userscript-tip{display:none !important;}");
        console.log("host-----------------" + location.host);
        //alert("sdfsdf")
        // 对请求做代理
        const _fetch = unsafeWindow.fetch;
        unsafeWindow.fetch = async function (...args) {
            try {
                let response = await _fetch(...args);
                if (response.status !== 200) throw new Error(response.status);
                return response;
            } catch (e) {
                // 失败请求使用代理
                if (args.length == 1) {
                    console.log(`请求代理:${args[0]}`);
                    return await new Promise((resolve, reject) => {
                        let referer = new URLSearchParams(location.hash.slice(1)).get("referer");
                        let headers = {};
                        if (referer) {
                            referer = new URL(referer);
                            headers = {
                                "origin": referer.origin,
                                "referer": referer.href
                            };
                        }
                        mgmapi.xmlHttpRequest({
                            method: "GET",
                            url: args[0],
                            responseType: 'arraybuffer',
                            headers,
                            onload(r) {
                                resolve({
                                    status: r.status,
                                    headers: new Headers(r.responseHeaders.split("\n").filter(n => n).map(s => s.split(/:\s*/)).reduce((all, [a, b]) => { all[a] = b; return all; }, {})),
                                    async text() {
                                        return r.responseText;
                                    },
                                    async arrayBuffer() {
                                        return r.response;
                                    }
                                });
                            },
                            onerror() {
                                reject(new Error());
                            }
                        });
                    });
                } else {
                    throw e;
                }
            }
        }

        return;
    }

}
)();