Greasy Fork is available in English.

【智狐】全网VIP视频解析无广告播放,文库下载器,支持B站大会员番剧、视频批量下载,全网独创自由选择自动解析接口|短视频无水印下载|淘宝、天猫、京东优惠券查询|更多功能持续更新中

【❤️ 视频自动解析,体会拥有VIP的感觉❤️,适配PC+移动 】功能有:1、支持B站大会员番剧,全网独创自由选择自动解析接口;2、爱奇艺、腾讯、优酷、芒果等全网VIP视频免费解析去广告(免跳出观影特方便);3.B站多P下载;抖音、西瓜视频、快手无水印下载;4.淘宝、天猫、京东优惠券查询5.新增喜马拉雅有声书批量下载,6.教育盘论坛免费下载,7.原创力文档、道客巴巴、智库文库免费下载8.解除CSDN博客登陆后复制限制,解除阅读全文限制,解除外链重定向限制

Versione datata 08/08/2022. Vedi la nuova versione l'ultima versione.

// ==UserScript==
// @name         【智狐】全网VIP视频解析无广告播放,文库下载器,支持B站大会员番剧、视频批量下载,全网独创自由选择自动解析接口|短视频无水印下载|淘宝、天猫、京东优惠券查询|更多功能持续更新中
// @namespace    http://www.zhihupe.com/
// @version      1.40
// @author       zhihu
// @description  【❤️ 视频自动解析,体会拥有VIP的感觉❤️,适配PC+移动 】功能有:1、支持B站大会员番剧,全网独创自由选择自动解析接口;2、爱奇艺、腾讯、优酷、芒果等全网VIP视频免费解析去广告(免跳出观影特方便);3.B站多P下载;抖音、西瓜视频、快手无水印下载;4.淘宝、天猫、京东优惠券查询5.新增喜马拉雅有声书批量下载,6.教育盘论坛免费下载,7.原创力文档、道客巴巴、智库文库免费下载8.解除CSDN博客登陆后复制限制,解除阅读全文限制,解除外链重定向限制
// @icon         https://www.zhihupe.com/favicon.ico
// @require      https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/crypto-js/4.1.1/crypto-js.min.js
// @require      https://lib.baomitu.com/echarts/4.6.0/echarts.min.js
// @match          *://laisoyiba.com/*
// @match           *://*.youku.com/v_*
// @match           *://*.iqiyi.com/v_*
// @match           *://*.iqiyi.com/w_*
// @match           *://*.iqiyi.com/a_*
// @match           *://v.qq.com/x/cover/*
// @match           *://v.qq.com/x/page/*
// @match           *://v.qq.com/tv/*
// @match           *://*.mgtv.com/b/*
// @match           *://*.bilibili.com/video/*
// @match           *://*.bilibili.com/bangumi/play/*
// @match           *://www.acfun.cn/bangumi/*
// @match           *://www.le.com/ptv/vplay/*
// @match           *://www.wasu.cn/Play/show/*
// @match           *://vip.1905.com/play/*
// @match           *://tv.sohu.com/v/*
// @match           *://film.sohu.com/album/*
// @match           *://v.pptv.com/show/*

// @match           *://m.v.qq.com/*
// @match           *://m.iqiyi.com/v_*
// @match           *://m.iqiyi.com/w_*
// @match           *://m.iqiyi.com/a_*
// @match           *://m.youku.com/alipay_video/*
// @match           *://m.youku.com/video/*
// @match           *://m.mgtv.com/b/*
// @match           *://m.bilibili.com/video/*
// @match           *://m.bilibili.com/anime/*
// @match           *://m.bilibili.com/bangumi/play/*
// @match           *://m.le.com/vplay_*
// @match           *://vip.1905.com/m/play/*
// @match           *://www.wasu.cn/wap/Play/show/*
// @match           *://m.tv.sohu.com/v.*
// @match           *://m.pptv.com/show/*

// @match        *://item.taobao.com/*
// @match        *://s.taobao.com/*
// @match        *://chaoshi.detail.tmall.com/*
// @match        *://*detail.tmall.com/*
// @match        *://*detail.tmall.hk/*
// @match        *://list.tmall.com/search_*
// @match        *://*item.jd.com/*
// @match        *://npcitem.jd.hk/*
// @match        *://*.yiyaojd.com/*
// @match        *://search.jd.com/Search*

// @match         *://*jiaoyupan.com/forum.php?mod=viewthread&tid=*

// @match         *://*.book118.com/html/*
// @match         *://view-cache.book118.com/*
// @match         *://*.book118.com/?readpage*
// @match         *://*.doc88.com/p*
// @match         *://*.mbalib.com/view*

// @match         *://www.ximalaya.com/*
// @match         *://blog.csdn.net/*
// @match        *://*.douyin.com/video/*
// @match        *.kuaishou.com/short-video/*
// @match        *.kuaishou.com/video/*
// @match        *.ixigua.com/*
// @connect      tool.zhihupe.com
// @connect      47.99.158.118
// @connect      api.bilibili.com
// @connect      mobile.ximalaya.com
// @connect      v2.api.haodanku.com
// @connect      www.iesdouyin.com
// @connect      bijiatool-v2.manmanbuy.com
// @connect      view-cache.book118.com
// @grant        GM_openInTab
// @grant        GM.openInTab
// @grant        GM_getValue
// @grant        GM.getValue
// @grant        GM_setValue
// @grant        GM.setValue
// @grant        GM_xmlhttpRequest
// @grant        GM.xmlHttpRequest
// @grant        GM_addStyle

// @grant        GM_deleteValue
// @grant        GM_setClipboard
// @grant        GM_download
// @grant    GM_registerMenuCommand
// @grant    GM_unregisterMenuCommand
// @grant        unsafeWindow
// @run-at       document-body
// @license             End-User License Agreement
// @antifeature  	  referral-link 【此提示为GreasyFork代码规范要求含有查券功能的脚本必须添加,实际使用无任何强制跳转,代码可查,请知悉】
// ==/UserScript==

(function() {
    'use strict';
    //最终用户许可协议 End-User License Agreement
    // * Copyright (c) 2021-2022 zhihu. All Rights Reserved.
    // * Proprietary and Confidential.
    // * 该项目介绍、说明书、脚本代码、思路及其他相关
    //   内容版权归作者所有,未经作者本人书面授权,禁
    //   止任何单位或个人以任何形式、任何手段或通过任
    //   何方式(净室工程、手工、图片、电子、机械、磁
    //   性、化学、光学、声学或其它方式)抄袭、摘编、
    //   编辑、修改、结集、出版、再版、转录、转载、爬
    //   虫爬取、重制、仿制、复制、复写、复印、影印、
    //   拷贝、刻录、建立镜像、粘贴、张贴、派发、录音、
    //   用来创建派生作品、与其它任何资料进行合并、翻
    //   译成任何电脑语言或以其他任何方式用于商业或公
    //   共目的。
    // * 该项目仅仅准许您善意的使用,其他任何行为都是
    //   禁止的。
    // * zhihu从未授权任何组织或个人使用本项目脚本
    //   部分或全部代码创建作品。


    const config ={
        "playhref":window.location.href,
        "host":window.location.host,
        "UA":navigator.userAgent,
        "scriptInfo":GM_info.script,
        "hdapikey":"FF9529914C44",
    }
    const playList=[
        {"name":"M3U8.TV","category":1,"url":"https://jx.m3u8.tv/jiexi/?url=", "showType":3},
        {"name":"纯净/B站","category":1,"url":"https://z1.m1907.cn/?jx=", "showType":3},
        {"name":"高速接口","category":1,"url":"https://jsap.attakids.com/?url=", "showType":3},
        {"name":"综合/B站","category":1,"url":"https://jx.bozrc.com:4433/player/?url=", "showType":3},
        {"name":"OK解析","category":1,"url":"https://okjx.cc/?url=", "showType":3},
        {"name":"夜幕","category":1,"url":"https://www.yemu.xyz/?url=", "showType":3},
        {"name":"乐多资源","category":1,"url":"https://api.leduotv.com/wp-api/ifr.php?isDp=1&vid=", "showType":3},
        {"name":"爱豆","category":1,"url":"https://jx.aidouer.net/?url=", "showType":1},
        {"name":"虾米","category":1,"url":"https://jx.xmflv.com/?url=", "showType":1},
        {"name":"七哥","category":1,"url":"https://jx.mmkv.cn/tv.php?url=", "showType":3},
        {"name":"冰豆","category":1,"url":"https://api.qianqi.net/vip/?url=", "showType":3},
        {"name":"CK","category":1,"url":"https://www.ckplayer.vip/jiexi/?url=", "showType":1},
        {"name":"ckmov","category":1,"url":"https://www.ckmov.vip/api.php?url=", "showType":1},
        {"name":"playerjy/B站","category":1,"url":"https://jx.playerjy.com/?url=", "showType":3},
        {"name":"1717解析","category":1,"url":"https://ckmov.ccyjjd.com/ckmov/?url=", "showType":1},
        {"name":"H8","category":1,"url":"https://www.h8jx.com/jiexi.php?url=", "showType":1},
        {"name":"BL","category":1,"url":"https://vip.bljiex.com/?v=", "showType":1},
        {"name":"解析la","category":1,"url":"https://api.jiexi.la/?url=", "showType":1},
        {"name":"MAO","category":1,"url":"https://www.mtosz.com/m3u8.php?url=", "showType":1},
        {"name":"老板","category":1,"url":"https://vip.laobandq.com/jiexi.php?url=", "showType":1},
        {"name":"盘古","category":1,"url":"https://www.pangujiexi.cc/jiexi.php?url=", "showType":1},
        {"name":"盖世","category":1,"url":"https://www.gai4.com/?url=", "showType":1},
        {"name":"0523","category":1,"url":"https://go.yh0523.cn/y.cy?url=", "showType":1},
        {"name":"17云","category":1,"url":"https://www.1717yun.com/jx/ty.php?url=", "showType":1},
        {"name":"4K","category":1,"url":"https://jx.4kdv.com/?url=", "showType":1},
        {"name":"云析","category":1,"url":"https://jx.yparse.com/index.php?url=", "showType":1},
        {"name":"8090","category":1,"url":"https://www.8090g.cn/?url=", "showType":1},
        {"name":"PM","category":1,"url":"https://www.playm3u8.cn/jiexi.php?url=", "showType":1},
        {"name":"无名","category":1,"url":"https://www.administratorw.com/video.php?url=", "showType":1},

        {"name":"综合线路","category":2,"url":"https://zhihuweb.com/player.html?url=", "showType":1},
        {"name":"纯净/B站","category":2,"url":"https://z1.m1907.cn/?jx=", "showType":1},
        {"name":"高速接口","category":2,"url":"https://jsap.attakids.com/?url=", "showType":1},
        {"name":"综合/B站1","category":2,"url":"https://jx.bozrc.com:4433/player/?url=", "showType":1},
        {"name":"OK解析","category":2,"url":"https://okjx.cc/?url=", "showType":1},
        {"name":"夜幕","category":2,"url":"https://www.yemu.xyz/?url=", "showType":1},
        {"name":"虾米","category":2,"url":"https://jx.xmflv.com/?url=", "showType":1},
        {"name":"M3U8.TV","category":2,"url":"https://jx.m3u8.tv/jiexi/?url=", "showType":1},
    ];
    var author = config.scriptInfo.author;

    var commonFunction = {
        Toast:function(msg, duration = 3000){
            var m = document.createElement('div');
            m.innerHTML = msg;
            m.setAttribute('id','msg');
            m.style.cssText = "max-width:60%;min-width: 150px;padding:0 14px;min-height: 40px;color: rgb(255, 255, 255);line-height: 40px;text-align: center;border-radius: 4px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 9999999999;background: rgba(0, 0, 0,.7);font-size: 16px;";
            document.body.appendChild(m);
            setTimeout(() => {
                var d = 0.5;
                m.style.webkitTransition = '-webkit-transform ' + d + 's ease-in, opacity ' + d + 's ease-in';
                m.style.opacity = '0';
                setTimeout(() => { document.body.removeChild(document.querySelector("#msg")) }, d * 1000);
            }, duration);
        },
        //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+
        GMopenInTab:function(url, open_in_background) {
            if (typeof GM_openInTab === "function") {
                GM_openInTab(url, open_in_background);
            } else {
                GM.openInTab(url, open_in_background);
            }
        },

        //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+
        GMgetValue:function(name, value) {
            if (typeof GM_getValue === "function") {
                return GM_getValue(name, value);
            } else {
                return GM.getValue(name, value);
            }
        },

        //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+
        GMsetValue:function(name, value) {
            if (typeof GM_setValue === "function") {
                GM_setValue(name, value);
            } else {
                GM.setValue(name, value);
            }
        },

        //兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+
        GMxmlhttpRequest:function(obj) {
            if (typeof GM_xmlhttpRequest === "function") {
                GM_xmlhttpRequest(obj);
            } else {
                GM.xmlhttpRequest(obj);
            }
        },
        setItem:function(name, Value) {
            localStorage.setItem(name, Value);
        },
        getItem:function(name) {
            let StorageValue = localStorage.getItem(name);
            return StorageValue;
        },
        removeItem:function(name) {
            localStorage.removeItem(name);
        },
        GMaddStyle:function(data,id=null) {
            var addStyle = document.createElement('style');
            addStyle.textContent = data;
            addStyle.type = 'text/css';
            addStyle.id = id;
            var doc = document.head || document.documentElement;
            doc.appendChild(addStyle);
        },
        GMaddScript:function(data) {
            let script = document.createElement('script');
            script.src = data;
            var docu = document.head || document.documentElement;
            docu.appendChild(script);
        },
        GMaddlink:function(data) {
            let mylink = document.createElement('link');
            mylink.href = data;
            mylink.rel = 'stylesheet';
            var docl = document.head || document.documentElement;
            docl.appendChild(mylink);
        },
        GMopenInTab:function(url, open_in_background) {
            if (typeof GM_openInTab === "function") {
                GM_openInTab(url, open_in_background);
            } else {
                GM.openInTab(url, open_in_background);
            }
        },
        sleep:function(time) {
            return new Promise(resolve => setTimeout(resolve, time));
        },
        Commonsetinterval:function(data){
            var Count;
            var num ="";
            return new Promise(function(resolve, reject){
                Count = setInterval(function() {
                    var node = document.querySelector(data);
                    num++;
                    if(node != null ){
                        resolve(node);
                        clearInterval(Count);
                    }
                    if(num ==100){
                        clearInterval(Count);
                    }
                    console.log(node)
                },200);
            });
        },
        Videosetinterval:function(data){
            var Count;
            return new Promise(function(resolve, reject){
                Count = setInterval(function() {
                    var node = document.querySelector(data).children;
                    if(node != null ){
                        resolve(Count);
                        console.log(node)
                    }
                    console.log(node)
                },200);
            });
        },
        menusetting:function(){
            //初始化脚本设置
            if(commonFunction.GMgetValue("videosetting")==null){
                commonFunction.GMsetValue("videosetting",1);
            }
            if(commonFunction.GMgetValue("couponsetting")==null){
                commonFunction.GMsetValue("couponsetting",1);
            }
            if(commonFunction.GMgetValue("historysetting")==null){
                commonFunction.GMsetValue("historysetting",1);
            }
            if(commonFunction.GMgetValue("Shortvideosetting")==null){
                commonFunction.GMsetValue("Shortvideosetting",1);
            }
            if(commonFunction.GMgetValue("Bilibilisetting")==null){
                commonFunction.GMsetValue("Bilibilisetting",1);
            }
            if(commonFunction.GMgetValue("Ximalayasetting")==null){
                commonFunction.GMsetValue("Ximalayasetting",1);
            }
            if(commonFunction.GMgetValue("Jiaoyupansetting")==null){
                commonFunction.GMsetValue("Jiaoyupansetting",1);
            }
            if(commonFunction.GMgetValue("Docssetting")==null){
                commonFunction.GMsetValue("Docssetting",1);
            }
            if(commonFunction.GMgetValue("Csdnsetting")==null){
                commonFunction.GMsetValue("Csdnsetting",1);
            }
        },
        setIntervalhost:function() {
            setInterval(function() {
                var workurl = window.location.href;
                if (config.playhref != workurl) {
                    console.log(workurl);
                    config.playhref = workurl;
                    window.location.reload();
                }
            },500);
        },
        IsPC:function() {
            var userAgentInfo = config.UA;
            var Agents = ["Android", "iPhone","SymbianOS", "Windows Phone", "iPad", "iPod"];
            var flag = true;
            for (let i = 0; i < Agents.length; i++) {
                if (userAgentInfo.indexOf(Agents[i]) > 0) {
                    flag = false;
                    break;
                }
            }
            return flag;
        },
        IsWap:function(){
            var com = null;
            if(config.host.indexOf('item.') > -1) {
                com = "pc";
            }else if (config.host.indexOf('m.') > -1||config.playhref.indexOf('/m/') > -1||config.playhref.indexOf('/wap/') > -1) {
                com = "wap";
            }else {
                com = "pc";
            }
            return com
        },
        Getgoodid:function(data){
            var reg = new RegExp("(^|&)" + data + "=([^&]*)(&|$)");
            var s = window.location.search.substr(1).match(reg);
            if (s != null) {
                return s[2];
            }
            return "";
        },
        geturlid:function(url) {
            var id ="";
            if (url.indexOf("?") != -1) {
                url = url.split("?")[0]
            }
            if (url.indexOf("#") != -1) {
                url = url.split("#")[0]
            }
            var text = url.split("/");
            id = text[text.length - 1];
            id = id.replace(".html", "");
            return id
        },
        request:function(method,url,headers,data=null){
            return new Promise(function(resolve, reject){
                commonFunction.GMxmlhttpRequest({
                    url: url,
                    method: method,
                    data:data,
                    headers:headers,
                    onload: function(res) {
                        var status = res.status;
                        var responseText = res.responseText;
                        if(status==200||status=='200'){
                            resolve({"result":"success", "data":responseText});
                        }else{
                            reject({"result":"error", "data":null});
                        }
                    }
                });
            })
        },
        open:function(data){
            var main = document.createElement('div');
            var width = data.area[0];
            var height = data.area[1];
            var margintop = height/2;
            var marginleft = width/2;
            var style = "z-index: 999999998;width: "+width+"px;height:"+height+"px;position: fixed;top: 50%;left: 50%;margin-left:-"+marginleft+"px;margin-top:-"+margintop+"px;"
            var btnHTML = '<a class="zhihu-layer-btn0">'+data.btn[0]+'</a><a class="zhihu-layer-btn1">'+data.btn[1]+'</a>';
            main.innerHTML = '<div class="zhihu-layer-title" style="cursor: move;">'+data.title+'</div><div class="zhihu-layer-content" >'+data.content+'</div><span class="zhihu-layer-setwin"><a class="zhihu-layer-ico zhihu-layer-close1" href="javascript:;"></a></span><div class="zhihu-layer-btn zhihu-layer-btn-c">'+btnHTML+'</div>';
            main.setAttribute('id',data.id);
            main.setAttribute('style',style);
            main.setAttribute('class',"zhihu-layer-page");
            document.body.appendChild(main);
            var shade = document.createElement('div');
            shade.setAttribute('style',"z-index: 999999997;background-color: rgb(0, 0, 0);opacity: 0.3;");
            shade.setAttribute('class',"zhihu-layer-shade");
            shade.setAttribute('id',"zhihu-layer-shade");
            shade.innerHTML =''
            document.body.appendChild(shade);
            var css = `
             ::-webkit-scrollbar {
                height: 6px;
                width: 6px;
             }
             ::-webkit-scrollbar-track {
                background: transparent;
                width: 6px;
             }
             ::-webkit-scrollbar-thumb {
                background-color: #54be99;
                border-radius: 4px;
                -webkit-transition: all 1s;
                transition: all 1s;
                width: 6px;
             }
             ::-webkit-scrollbar-corner {
                background-color: #54be99;
             }
             li {
               list-style: none;
             }
             .zhihu-form-label, .zhihu-form-select, .zhihu-input-block, .zhihu-input-inline{
               position: relative;
             }
             .zhihu-layer-shade {
               top: 0;
               left: 0;
               width: 100%;
               height: 100%;
               position: fixed;
               _height: expression(document.body.offsetHeight+"px");
             }
             .zhihu-layer-page{
                   margin: 0;
                   padding: 0;
                   background-color: #fff;
                   border-radius: 10px;
                   box-shadow: 1px 1px 50px rgba(0,0,0,.4);
                   font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;
             }
             .zhihu-layer-title{
                   padding: 0 80px 0 20px;
                   height: 50px;
                   line-height: 50px;
                   border-bottom: 1px solid #F0F0F0;
                   border-radius: 2px 2px 0 0;
                   font-size: 14px;
                   color: #333;
                   overflow: visible;
                   text-overflow: ellipsis;
                   white-space: nowrap;
                   font-weight: bold;
             }
             .zhihu-layer-setwin {
                   position: absolute;
                   right: 15px;
                   top: 17px;
                   font-size: 0;
                   line-height: initial;
              }
              .zhihu-layer-setwin .zhihu-layer-close1 {
                   background-position: 1px -40px;
                   cursor: pointer;
              }
              .zhihu-layer-setwin a {
                   position: relative;
                   width: 16px;
                   height: 16px;
                   margin-left: 10px;
                   font-size: 12px;
                   _overflow: hidden;
              }
             .zhihu-layer-btn a, .zhihu-layer-setwin a {
                   display: inline-block;
                   vertical-align: top;
              }
              .zhihu-layer-ico {
                   background: url(https://www.layuicdn.com/layui/css/modules/layer/default/icon.png) no-repeat;
              }
              .zhihu-layer-btn {
                   text-align: right;
                   padding: 10px 15px 12px;
                   pointer-events: auto;
                   user-select: none;
                   -webkit-user-select: none;
              }
              .zhihu-layer-btn-c {
                   text-align: center;
              }
              .zhihu-layer-btn a {
                   height: 28px;
                   line-height: 28px;
                   margin: 5px 5px 0;
                   padding: 0 15px;
                   border: 1px solid #dedede;
                   background-color: #fff;
                   color: #333;
                   border-radius: 4px;
                   font-weight: 400;
                   cursor: pointer;
                   text-decoration: none;
               }
               .zhihu-layer-btn1 {
                   border-color: #54be99!important;
                   background-color: #54be99!important;
                   color: #fff!important;
               }
               .zhihu-form-item {
                   margin-bottom: 5px;
                   clear: both;
               }
               .zhihu-form-label {
                   float: left;
                   display: block;
                   padding: 9px 15px;
                   width: 80px;
                   font-weight: 400;
                   line-height: 20px;
                   text-align: right;
                   box-sizing: content-box;
                }
                .zhihu-input-inline {
                   display: inline-block;
                   vertical-align: middle;
                   width: 190px;
                   margin-right: 10px;
                }
                .zhihu-input, .zhihu-select, .zhihu-textarea {
                   height: 38px;
                   line-height: 1.3;
                   border-width: 1px;
                   border-style: solid;
                   border-color: #eee;
                   display: block;
                   width: 100%;
                   padding-left: 10px;
                   background-color: #fff;
                   color: rgba(0,0,0,.85);
                   border-radius: 2px;
                   outline: 0;
                   -webkit-appearance: none;
                   transition: all .3s;
                   -webkit-transition: all .3s;
                   box-sizing: border-box;
                }
                .zhihu-input-block {
                   min-height: auto;
                   margin-left: 110px;
                }
                .zhihu-input-block p {
                   font-size: 12px;
                   line-height: 22px;
                }
                .zhihu-form {
                   display: flex;
                   margin-top: 20px;
                }

            `;
            commonFunction.GMaddStyle(css,"open");
            // await commonFunction.sleep(1000);
            //获取表单对象
            var zhihuform = document.querySelector('.zhihu-form');
            //保存按钮点击事件
            document.querySelector('.zhihu-layer-btn1').addEventListener('click',function() {
                data.btn1(zhihuform);
                document.body.removeChild(document.querySelector(".zhihu-layer-page"));
                document.body.removeChild(document.querySelector("#zhihu-layer-shade"));
                document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open"));
            })
            //取消钮点击事件
            document.querySelector(".zhihu-layer-btn0").addEventListener('click',function() {
                document.body.removeChild(document.querySelector(".zhihu-layer-page"));
                document.body.removeChild(document.querySelector("#zhihu-layer-shade"));
                document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open"));
            })
            //关闭钮点击事件
            document.querySelector(".zhihu-layer-close1").addEventListener('click',function() {
                document.body.removeChild(document.querySelector(".zhihu-layer-page"));
                document.body.removeChild(document.querySelector("#zhihu-layer-shade"));
                document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open"));
            })
        },
        tab:async function(data){
            var main = document.createElement('div');
            var width = data.area[0];
            var height = data.area[1];
            var margintop = height/2;
            var marginleft = width/2;
            var style = "z-index: 999999998;width: "+width+"px;height:"+height+"px;position: fixed;top: 50%;left: 50%;margin-left:-"+marginleft+"px;margin-top:-"+margintop+"px;"
            var titleHTML ="";
            var contentHTML = "";
            var btnHTML = '<a class="zhihu-layer-btn0">'+data.btn[0]+'</a><a class="zhihu-layer-btn1">'+data.btn[1]+'</a>'
            for (let i = 0; i < data.tab.length; i++) {
                if(i === 0 ){
                    titleHTML +='<span class="tab-title zhihu-this">'+data.tab[i].title+'</span>';
                    contentHTML += '<li class="zhihu-layer-tabli zhihu-this">'+data.tab[i].content+'</li>';
                }else{
                    titleHTML +='<span class="tab-title">'+data.tab[i].title+'</span>';
                    contentHTML += '<li class="zhihu-layer-tabli ">'+data.tab[i].content+'</li>';
                }
            }
            main.innerHTML = '<div class="zhihu-layer-title" style="cursor: move;">'+titleHTML+'</div><div class="zhihu-layer-content" ><ul class="zhihu-layer-tabmain">'+contentHTML+'</ul></div><span class="zhihu-layer-setwin"><a class="zhihu-layer-ico zhihu-layer-close1" href="javascript:;"></a></span><div class="zhihu-layer-btn zhihu-layer-btn-c">'+btnHTML+'</div>';
            main.setAttribute('id',data.id);
            main.setAttribute('style',style);
            main.setAttribute('class',"zhihu-layer-tab");
            document.body.appendChild(main);
            var tabtitle = document.getElementsByClassName('tab-title');
            for (let i = 0; i < tabtitle.length; i++) {
                let tabli = document.getElementsByClassName('zhihu-layer-tabli')[i];
                tabtitle[i].addEventListener('click',function() {
                    document.querySelector(".zhihu-layer-title>.zhihu-this").classList.remove("zhihu-this");
                    this.classList.add("zhihu-this");
                    document.querySelector(".zhihu-layer-tabmain>.zhihu-this").classList.remove("zhihu-this");
                    tabli.classList.add("zhihu-this");
                });

            }
            var shade = document.createElement('div');
            shade.setAttribute('style',"z-index: 999999997;background-color: rgb(0, 0, 0);opacity: 0.3;");
            shade.setAttribute('class',"zhihu-layer-shade");
            shade.setAttribute('id',"");
            shade.innerHTML =''
            document.body.appendChild(shade);
            var css = `
             ::-webkit-scrollbar {
                height: 6px;
                width: 6px;
             }
             ::-webkit-scrollbar-track {
                background: transparent;
                width: 6px;
             }
             ::-webkit-scrollbar-thumb {
                background-color: #54be99;
                border-radius: 4px;
                -webkit-transition: all 1s;
                transition: all 1s;
                width: 6px;
             }
             ::-webkit-scrollbar-corner {
                background-color: #54be99;
             }
             li {
               list-style: none;
             }
             .zhihu-form-label, .zhihu-form-select, .zhihu-input-block, .zhihu-input-inline{
               position: relative;
             }
             .zhihu-layer-shade {
               top: 0;
               left: 0;
               width: 100%;
               height: 100%;
               position: fixed;
               _height: expression(document.body.offsetHeight+"px");
             }
             .zhihu-layer-tab{
                   margin: 0;
                   padding: 0;
                   background-color: #fff;
                   border-radius: 10px;
                   box-shadow: 1px 1px 50px rgba(0,0,0,.4);
                   font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;
             }
             .zhihu-layer-title{
                   padding: 0 80px 0 20px;
                   height: 50px;
                   line-height: 50px;
                   border-bottom: 1px solid #F0F0F0;
                   border-radius: 2px 2px 0 0;
                   font-size: 14px;
                   color: #333;
                   padding-left: 0;
                   overflow: visible;
                   text-overflow: ellipsis;
                   white-space: nowrap;
             }
             .zhihu-layer-title span {
                   position: relative;
                   float: left;
                    min-width: 80px;
                   max-width: 300px;
                   padding: 0 20px;
                   text-align: center;
                   overflow: hidden;
                   cursor: pointer;
                   font-weight: bold;
                   color: #000;
              }
              .zhihu-layer-title span:first-child {
                   border-left: none;
              }
              .zhihu-layer-title span.zhihu-this {
                   height: 51px;
                   border-left: 1px solid #eee;
                   border-right: 1px solid #eee;
                   background-color: #fff;
                   z-index: 10;
              }
              .zhihu-layer-title span:first-child.zhihu-this {
                    border-radius: 10px 0 0 0;
              }
              .zhihu-layer-content {
                   position: relative;
                   overflow: hidden;
                   height:290px;
              }
              .zhihu-layer-tabmain {
                   line-height: 24px;
                   clear: both;
                   padding: 0;
                   margin: 0;
              }
              .zhihu-layer-tabli{
                   display:none;
                   height: 100%;
              }
              .zhihu-layer-tabmain .zhihu-this{
                   display:block;
              }
              .zhihu-layer-setwin {
                   position: absolute;
                   right: 15px;
                   top: 17px;
                   font-size: 0;
                   line-height: initial;
              }
              .zhihu-layer-setwin .zhihu-layer-close1 {
                   background-position: 1px -40px;
                   cursor: pointer;
              }
              .zhihu-layer-setwin a {
                   position: relative;
                   width: 16px;
                   height: 16px;
                   margin-left: 10px;
                   font-size: 12px;
                   _overflow: hidden;
              }
             .zhihu-layer-btn a, .zhihu-layer-setwin a {
                   display: inline-block;
                   vertical-align: top;
              }
              .zhihu-layer-ico {
                   background: url(https://www.layuicdn.com/layui/css/modules/layer/default/icon.png) no-repeat;
              }
              .zhihu-layer-btn {
                   text-align: right;
                   padding: 10px 15px 12px;
                   pointer-events: auto;
                   user-select: none;
                   -webkit-user-select: none;
              }
              .zhihu-layer-btn-c {
                   text-align: center;
              }
              .zhihu-layer-btn a {
                   height: 28px;
                   line-height: 28px;
                   margin: 5px 5px 0;
                   padding: 0 15px;
                   border: 1px solid #dedede;
                   background-color: #fff;
                   color: #333;
                   border-radius: 4px;
                   font-weight: 400;
                   cursor: pointer;
                   text-decoration: none;
               }
               .zhihu-layer-btn1 {
                   border-color: #54be99!important;
                   background-color: #54be99!important;
                   color: #fff!important;
               }

               .zhihu-form-item {
                   margin-bottom: 15px;
                   clear: both;
               }
               .zhihu-form-label {
                   float: left;
                   display: block;
                   padding: 9px 15px;
                   width: 80px;
                   font-weight: 400;
                   line-height: 20px;
                   text-align: right;
               }
               .zhihu-input-block {
                   margin-left: 110px;
                   min-height: 36px;
                   width: 190px;
               }
               .zhihu-form input[type=checkbox], .zhihu-form input[type=radio], .zhihu-form select {
                   display: none;
               }
               .zhihu-form-switch {
                   position: relative;
                   height: 22px;
                   line-height: 22px;
                   min-width: 35px;
                   padding: 0 5px;
                   margin-top: 8px;
                   border: 1px solid #d2d2d2;
                   border-radius: 20px;
                   cursor: pointer;
                   background-color: #fff;
                   -webkit-transition: .1s linear;
                   transition: .1s linear;
               }
               .zhihu-form-checkbox, .zhihu-form-checkbox *, .zhihu-form-switch {
                   display: inline-block;
                   vertical-align: middle;
               }
               .zhihu-unselect {
                   -moz-user-select: none;
                   -webkit-user-select: none;
                   -ms-user-select: none;
               }
               .zhihu-form-switch em {
                   position: relative;
                   top: 0;
                   width: 25px;
                   margin-left: 21px;
                   padding: 0!important;
                   text-align: center!important;
                   color: #999!important;
                   font-style: normal!important;
                   font-size: 12px;
               }
               .zhihu-form-switch i {
                   position: absolute;
                   left: 5px;
                   top: 3px;
                   width: 16px;
                   height: 16px;
                   border-radius: 20px;
                   background-color: #d2d2d2;
                   -webkit-transition: .1s linear;
                   transition: .1s linear;
               }
               .zhihu-form-onswitch {
                   border-color: #54be99;
                   background-color: #54be99;
               }
               .zhihu-form-onswitch em {
                   margin-left: 5px;
                   margin-right: 21px;
                   color: #fff!important;
               }
               .zhihu-form-onswitch i {
                   left: 100%;
                   margin-left: -21px;
                   background-color: #fff;
               }
               .zhihu-form-select .zhihu-input {
                   padding-right: 30px;
                   cursor: pointer;
               }
               .zhihu-input, .zhihu-textarea {
                   display: block;
                   width: 100%;
                   padding-left: 10px;
               }
               .zhihu-input, .zhihu-select, .zhihu-textarea {
                   height: 38px;
                   line-height: 1.3;
                   border-width: 1px;
                   border-style: solid;
                   background-color: #fff;
                   color: rgba(0,0,0,.85);
                   border-radius: 2px;
               }
               .zhihu-btn, .zhihu-input, .zhihu-select, .zhihu-textarea, .zhihu-upload-button {
                   outline: 0;
                   -webkit-appearance: none;
                   transition: all .3s;
                   -webkit-transition: all .3s;
                   box-sizing: border-box;
                   border-color: #eee;
               }
               .zhihu-form-select .zhihu-edge {
                   position: absolute;
                   right: 10px;
                   top: 50%;
                   margin-top: -3px;
                   cursor: pointer;
                   border-width: 6px;
                   border-top-color: #c2c2c2;
                   border-top-style: solid;
                   transition: all .3s;
                   -webkit-transition: all .3s;
               }
               .zhihu-edge {
                   width: 0;
                   border-width: 6px;
                   border-style: dashed;
                   border-color: transparent;
               }
               .zhihu-edge {
                   display: inline-block;
               }
               .zhihu-form-selected .zhihu-edge {
                   margin-top: -9px;
                   -webkit-transform: rotate(180deg);
                   transform: rotate(180deg);
               }
               .zhihu-anim {
                   -webkit-animation-duration: .3s;
                   -webkit-animation-fill-mode: both;
                   animation-duration: .3s;
                   animation-fill-mode: both;
               }
               .zhihu-form-select dl, .zhihu-panel {
                   box-shadow: 1px 1px 4px rgb(0 0 0 / 8%);
               }
               .zhihu-form-select dl {
                   display: none;
                   position: absolute;
                   left: 0;
                   top: 42px;
                   padding: 5px 0;
                   z-index: 899;
                   min-width: 100%;
                   border: 1px solid #eee;
                   max-height: 300px;
                   overflow-y: auto;
                   background-color: #fff;
                   border-radius: 2px;
                   box-sizing: border-box;
                   margin: 0;
               }
               .zhihu-form-selected dl {
                   display: block;
               }
               .zhihu-form-select dl dd, .zhihu-form-select dl dt {
                   padding: 0 10px;
                   line-height: 36px;
                   white-space: nowrap;
                   overflow: hidden;
                   text-overflow: ellipsis;
                   margin: 0;
               }
               .zhihu-form-select dl dd {
                   cursor: pointer;
               }
               .zhihu-form-select dl dd.zhihu-select-tips{
                   padding-left: 10px!important;
                   color: #999;
               }
               .zhihu-form-select dl dd.zhihu-this{
                   background-color: #5FB878;
                   color: #fff;
               }
         `;
            commonFunction.GMaddStyle(css,"tab");
            await commonFunction.sleep(1000);
            //获取表单对象
            var zhihuform = document.querySelector('.zhihu-form');
            //保存按钮点击事件
            document.querySelector('.zhihu-layer-btn1').addEventListener('click',function() {
                data.btn1(zhihuform);
                document.body.removeChild(document.querySelector(".zhihu-layer-tab"));
                document.body.removeChild(document.querySelector(".zhihu-layer-shade"));
                document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab"));
            })
            //取消钮点击事件
            document.querySelector(".zhihu-layer-btn0").addEventListener('click',function() {
                document.body.removeChild(document.querySelector(".zhihu-layer-tab"));
                document.body.removeChild(document.querySelector(".zhihu-layer-shade"));
                document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab"));
            })
            //关闭钮点击事件
            document.querySelector(".zhihu-layer-close1").addEventListener('click',function() {
                document.body.removeChild(document.querySelector(".zhihu-layer-tab"));
                document.body.removeChild(document.querySelector(".zhihu-layer-shade"));
                document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab"));
            })
            //开关添加开始
            var zhihuinput = zhihuform.getElementsByClassName('checkbox');
            for (let i = 0; i < zhihuinput.length; i++) {
                let name = zhihuinput[i].getAttribute("name");
                if(name =="switch"){
                    if(zhihuinput[i].checked){
                        zhihuinput[i].insertAdjacentHTML('afterEnd', '<div class="zhihu-unselect zhihu-form-switch zhihu-form-onswitch"><em>ON</em><i></i></div>');
                    }else{
                        zhihuinput[i].insertAdjacentHTML('afterEnd', '<div class="zhihu-unselect zhihu-form-switch "><em>OFF</em><i></i></div>');
                    }
                }
            }
            //开关添加结束
            //开关点击事件开始
            var zhihuswitch = document.getElementsByClassName('zhihu-form-switch');
            for (let i = 0; i < zhihuinput.length; i++) {
                zhihuswitch[i].addEventListener('click',function() {
                    let onswitch = this.getAttribute("class");
                    if(onswitch.indexOf("zhihu-form-onswitch")!=-1){
                        this.parentNode.querySelector('input').removeAttribute("checked");
                        this.classList.remove("zhihu-form-onswitch");
                        this.innerHTML ="<em>OFF</em><i></i>"
                    }else{
                        this.parentNode.querySelector('input').setAttribute("checked",true);
                        this.classList.add("zhihu-form-onswitch");
                        this.innerHTML ="<em>ON</em><i></i>"
                    }

                })
            }
            //开关点击事件结束
            //下拉框添加开始
            var zhihuselect = zhihuform.getElementsByTagName('select');
            for (let i = 0; i < zhihuselect.length; i++) {
                let optionHtml ='';
                let zhihuoption = zhihuselect[i].getElementsByTagName('option');
                if(zhihuselect[i].selectedIndex < 0){
                    var Index = 0
                    }else{
                        Index = zhihuselect[i].selectedIndex;
                    }
                let selecttext = zhihuselect[i].options[Index].text;
                var selectvalue = zhihuselect[i].options[Index].value;
                for (let l = 0; l < zhihuoption.length; l++) {
                    let optionText = zhihuoption[l].innerText;
                    let optionvalue = zhihuoption[l].value;
                    if(optionvalue == selectvalue){
                        optionHtml += '<dd zhihu-value="'+optionvalue+'"  class="zhihu-select-tips zhihu-this">'+optionText+'</dd>'
                    }else{
                        optionHtml += '<dd zhihu-value="'+optionvalue+'" class="">'+optionText+'</dd>'
                    }
                }
                var selectHtml = '<div class="zhihu-unselect zhihu-form-select"><div class="zhihu-select-title"><input type="text" placeholder="直接选择或搜索选择" value="'+selecttext+'" readonly="" class="zhihu-input zhihu-unselect"><i class="zhihu-edge"></i></div><dl class="zhihu-anim" style="">'+optionHtml+'</dl></div>';
                zhihuselect[i].insertAdjacentHTML('afterEnd',selectHtml);
            }
            //下拉框添加结束
            //下拉框操作事件开始
            var zhihuunselect = document.getElementsByClassName("zhihu-form-select");
            for (let i = 0; i < zhihuunselect.length; i++) {
                //下拉框点击事件
                zhihuunselect[i].addEventListener('click',function() {
                    var selected = this.getAttribute("class");
                    if(selected.indexOf("zhihu-form-selected")!=-1){
                        this.classList.remove("zhihu-form-selected");
                    }else{
                        this.classList.add("zhihu-form-selected");
                    };
                },false);
                //下拉框选择事件
                var zhihudd = zhihuunselect[i].getElementsByTagName('dd');
                for (let l = 0; l < zhihudd.length; l++) {
                    zhihudd[l].addEventListener('click',function() {
                        var a = zhihuunselect[i].querySelector('.zhihu-this');
                        if(a){
                            a.classList.remove("zhihu-this");
                            a.classList.remove("zhihu-select-tips");
                        }
                        this.classList.add("zhihu-this");
                        this.classList.add("zhihu-select-tips");
                        console.log(this.getAttribute("zhihu-value"));
                        console.log(zhihuunselect[i].parentNode.querySelector('select'))
                        zhihuunselect[i].parentNode.querySelector('select').value = this.getAttribute("zhihu-value");
                        zhihuunselect[i].parentNode.querySelector('input').setAttribute("value",this.innerText);
                    });
                };
            }
            //下拉框操作事件结束
        },
    }
    //--------------------------------------------------------------
    var ControllerVideo = {
        //播放节点
        Playid:function(){
            var PlayidList = [
                { url:"v.qq.com", node:"#mod_player"},
                { url:"www.iqiyi.com", node:"#flashbox"},
                { url:"v.youku.com", node:"#player"},
                { url:"w.mgtv.com", node:"#mgtv-player-wrap"},
                { url:"www.mgtv.com", node:"#mgtv-player-wrap"},
                { url:"tv.sohu.com", node:"#player"},
                { url:"film.sohu.com", node:"#playerWrap"},
                { url:"www.le.com", node:"#le_playbox"},
                { url:"v.pptv.com", node:"#pptv_playpage_box"},
                { url:"vip.pptv.com", node:".w-video"},
                { url:"www.wasu.cn", node:"#flashContent"},
                { url:"www.bilibili.com", node:"#player_module"},
                { url:"vip.1905.com", node:"#player"},
                { url:"m.v.qq.com", node:"#player"},
                { url:"m.youku.com", node:"#player"},
                { url:"m.iqiyi.com", node:".m-video-player-wrap"},
                { url:"m.mgtv.com", node:".video-area"},
                { url:"m.bilibili.com", node:"#bofqi"},
                { url:"m.le.com", node:"#j-player"},
                { url:"m.tv.sohu.com", node:".player"},
                { url:"m.pptv.com", node:".pp-details-video"},
            ];
            var Playid = null;
            for(let i in PlayidList) { //获得窗口ID
                if (PlayidList[i].url == config.host) {
                    if(config.playhref.indexOf("www.wasu.cn/wap/Play")!=-1){
                        Playid ="#pop"
                    }else if(PlayidList[i].url == "v.qq.com"){
                        var player = document.querySelector(".player_side_bd");
                        console.log(player)
                        if(player!=null){
                            Playid = "#mod_player";
                        }else{
                            Playid = "#player-container"
                        }
                    }else{
                        Playid = PlayidList[i].node;
                    }
                    return Playid
                    break;
                }
            }
            if(!Playid){
                return;
            }

        },
        //----------------------------------------------------------------------
        //接口列表
        Videolist:function(f){
            var ListHtml={
                "Insidehtml":"",
                "selecthtml":"",
                "mobhtml":"",
                "Outsidehtml":"",
            };
            //-----------------------------
            let v = commonFunction.GMgetValue("userplayurl");
            //  GM_deleteValue("userplayurl");
            if(v){
                var e = v.concat(f);
            }else{
                e = f;
            }

            console.log(f)
            console.log(e)
            for (let i = 0; i < e.length; i++) {
                if (e[i].category == 1) {
                    ListHtml.Insidehtml += "<span  class='jiexi inside' id='Inside_" + i + "'  title='" + e[i].name + "' data-index='" + i + "' data-url='" + e[i].url + "'>" + e[i].name + "</span>";
                    ListHtml.selecthtml += "<option value='" +i + "' name='select' data-url='" + e[i].url + "'>" + e[i].name + "</option>"
                    if (e[i].showType == 3) {
                        ListHtml.mobhtml += "<span  class='mob-jiexi' id='mob_" + i + "'  title='" + e[i].name + "' data-index='" + i + "' data-url='" + e[i].url + "'>" + e[i].name + "</span>";
                    }
                } else {
                    ListHtml.Outsidehtml += "<span  class='jiexi outside 'title='" + e[i].name + "' data-index='" + i + "' data-url='" + e[i].url + "'>" + e[i].name + "</span>";
                }

            }
            //-----------------------------
            return ListHtml
        },
        //增加接口列表
        Videoaddlist:function(){
            var addListHtml="";
            //-----------------------------
            let e = commonFunction.GMgetValue("userplayurl");
            console.log(e);
            if(e != null&&e != ""&&e != undefined){
                for (let i = 0; i < e.length; i++) {
                    if(e[i].category == 1){
                        addListHtml += '<li><span>'+e[i].name+'</span><span>内部播放</span><span class="urllist">'+e[i].url+'</span><span class="delurl" data-id='+i+'>删除</span></li>';
                    }else if(e[i].category == 2){
                        addListHtml += '<li><span>'+e[i].name+'</span><span>跳转播放</span><span class="urllist">'+e[i].url+'</span><span class="delurl" data-id='+i+'>删除</span></li>';
                    }else{
                        continue;
                    }
                }
            }else{
                addListHtml = '<p style="text-align: center;margin: 20px 0;">暂无数据</p>'
            }
            //-----------------------------
            return addListHtml
        },
        //----------------------------------------------------------------------
        //延迟时间
        Delay:function(){
             var Delaytime = commonFunction.getItem('Delaytime') != null ? commonFunction.getItem('Delaytime'): 3;
             unsafeWindow.zhihu = {
                   "Delaytime":Delaytime
            }
        },
        //电脑端
        addbtn:async function(){
            await commonFunction.sleep(1000);
            await ControllerVideo.Delay();
            ControllerVideo.CheckAutoplay();
            var css = `body, html {
		        font: 14px/1.5 "PingFang SC","微软雅黑","Microsoft YaHei",Helvetica,"Helvetica Neue",Tahoma,Arial,sans-serif;
		        color: #1c1f21;
		        height: 100%;
		    }
			.elevator {
				position: fixed;
				    padding: 0 16px;
				    top: 55%;
				    margin-top: -140px;
				    left: 0;
				    z-index: 999999996;
				    background: rgb(134 134 134 / 40%);
                    box-shadow: 1px 1px 8px 1px rgb(98 99 99 / 34%);
				    border-radius: 0 8px 8px 0;
			}

			.elevator a {
				position: relative;
				display: block;
				width: 26px;
				height: 56px;
				font-size: 22px;
				line-height: 20px;
				color: #b5b9bc;
				box-sizing: border-box;
				text-align: center;
			}

			.elevator a+a:after {
				position: absolute;
				top: 0;
				left: 50%;
				margin-left: -12px;
				content: '';
				width: 24px;
				border: 1px solid #F3F5F7;
			}

			.elevator a:hover {
				color: #14191e;
			}

			.elevator svg {
				font-size: 24px;
				line-height: 56px;
				color: #199b6d;
				width: 28px;
				height: 28px;
				margin: 14px 0;
			}

			.elevator svg:hover {
				color: #14191e;
			}

			.elevator a span {
				display: none;
				padding: 14px 0;
				font-size: 12px;
				color: #fff;
				line-height: 14px;
			}

			.elevator a:hover svg
			{
				display: none;
			}

			.elevator a:hover span
            {
				display: inline-block;
			}
			.jiexi{
				padding: 8px 10px;
				background: #e5e5e5a3;
				font-size: 12px;
				border-radius: 4px;
				margin:0 8px 10px 8px;
			    color: #505050;
				display: inline-block;
				width: 80px;
				text-align: center;
			}
			.jiexiselect{
				color: #fff;
				background:#54be99;
			}
            .zhihu-scan{
               width:144px;
			   display:inline-block;
			   text-align: center;
               margin-left:8px;
            }
			.zhihu-scan img{
				width: 140px;
				margin: 0 5px 10px 5px;
			}
			.zhihu-scan h1{
				font-size: 18px;
				font-weight: bold;
				margin: 0px 0 20px 0;
			}
			.zhihu-scan p{
			  margin: 0;
			  color: #666;
			  font-size: 12px;
              line-height: 26px;
			}
            .addlist{
              margin: 15px 0 0 0;
              padding: 0;
            }
            .addlist li{
              font-size: 14px;
              color: #333;
              line-height:36px;
              height: 36px;
            }
            .addlist li span{
              width: 100px;
              display: inline-block;
              text-align: center;
              overflow: hidden;
              font-size: 14px;
              color: #333;
              white-space:nowrap;
              text-overflow:ellipsis;
            }
            .addlist li .urllist{
              width: 214px;
            }
			::-webkit-input-placeholder{color:#999;font-size:12px;line-height:16px}
			:-moz-placeholder{color:#999;font-size:12px;line-height:16px}
			::-moz-placeholder{color:#999;font-size:12px;line-height:16px}
			:-ms-input-placeholder{color:#999;font-size:12px;line-height:16px}
            `;
            commonFunction.GMaddStyle(css);
            var btnhtml = '<div class="elevator" id=""><a href="javascript:;" class="elevator-msg" id="PlayMain"><svg t="1651763850342" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2320" width="200" height="200"><path d="M661.333333 665.6l51.2 12.8 42.666667-72.533333-34.133333-38.4c4.266667-21.333333 4.266667-38.4 4.266666-55.466667s0-34.133333-4.266666-51.2l34.133333-38.4-42.666667-72.533333-51.2 12.8c-25.6-21.333333-55.466667-42.666667-89.6-51.2L554.666667 256h-85.333334l-17.066666 51.2c-34.133333 8.533333-64 25.6-89.6 51.2l-51.2-12.8-42.666667 72.533333 34.133333 38.4c-4.266667 21.333333-4.266667 38.4-4.266666 55.466667s0 34.133333 4.266666 51.2l-34.133333 38.4 42.666667 72.533333 51.2-12.8c25.6 21.333333 55.466667 42.666667 89.6 51.2L469.333333 768h85.333334l17.066666-51.2c34.133333-8.533333 64-25.6 89.6-51.2z m38.4 81.066667c-21.333333 17.066667-51.2 34.133333-76.8 42.666666L597.333333 853.333333h-170.666666l-25.6-64c-29.866667-12.8-55.466667-25.6-76.8-42.666666l-68.266667 12.8-85.333333-149.333334 42.666666-51.2V512c0-17.066667 0-29.866667 4.266667-42.666667l-42.666667-51.2 85.333334-149.333333 68.266666 12.8c21.333333-17.066667 51.2-34.133333 76.8-42.666667L426.666667 170.666667h170.666666l25.6 64c29.866667 12.8 55.466667 25.6 76.8 42.666666l68.266667-12.8 85.333333 149.333334-42.666666 51.2c4.266667 12.8 4.266667 29.866667 4.266666 42.666666s0 29.866667-4.266666 42.666667l42.666666 51.2-85.333333 149.333333-68.266667-4.266666zM512 554.666667c25.6 0 42.666667-17.066667 42.666667-42.666667s-17.066667-42.666667-42.666667-42.666667-42.666667 17.066667-42.666667 42.666667 17.066667 42.666667 42.666667 42.666667z m0 85.333333c-72.533333 0-128-55.466667-128-128s55.466667-128 128-128 128 55.466667 128 128-55.466667 128-128 128z" fill="#ffffff" p-id="2321"></path></svg><span class="">解析设置</span></a><a href="javascript:;" id="addjiexi" class="elevator-faq" ><svg t="1656638904518" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="7918" width="200" height="200"><path d="M469.333333 469.333333V341.333333h85.333334v128h128v85.333334h-128v128h-85.333334v-128H341.333333v-85.333334h128z m42.666667 384c-187.733333 0-341.333333-153.6-341.333333-341.333333s153.6-341.333333 341.333333-341.333333 341.333333 153.6 341.333333 341.333333-153.6 341.333333-341.333333 341.333333z m0-85.333333c140.8 0 256-115.2 256-256s-115.2-256-256-256-256 115.2-256 256 115.2 256 256 256z" fill="#ffffff" p-id="7919"></path></svg><span class="">添加接口</span></a><a href="javascript:;" id="playing" class="elevator-faq" ><svg t="1651762741797" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1235" width="200" height="200"><path d="M512 853.333333c-187.733333 0-341.333333-153.6-341.333333-341.333333s153.6-341.333333 341.333333-341.333333 341.333333 153.6 341.333333 341.333333-153.6 341.333333-341.333333 341.333333z m0-85.333333c140.8 0 256-115.2 256-256s-115.2-256-256-256-256 115.2-256 256 115.2 256 256 256z m128-256l-213.333333 128V384l213.333333 128z" fill="#ffffff" p-id="1236"></path></svg><span class="">解析播放</span></a></div>';
            document.body.insertAdjacentHTML('afterbegin', btnhtml);
            commonFunction.removeItem('selectid');
            document.querySelector('#playing').onclick = function() {
                ControllerVideo.autoplay();
                commonFunction.Toast(`${unsafeWindow?.zhihu?.Delaytime??3}秒后自动解析视频`,`${unsafeWindow?.zhihu?.Delaytime??3}`*1000);
            };
            //弹窗开始-------------------------------------------------
            document.querySelector('#PlayMain').addEventListener('click',function() {
                console.log("点击成功");
                var ListHtml = ControllerVideo.Videolist(playList);
                //   console.log(ListHtml);
                var jiexi = commonFunction.getItem('AutoPlay') == 1 ? "checked": "";
                commonFunction.tab({
                    area: ['560', '400'],
                    id: "",
                    btn: ['取消', '保存设置'],
                    btnAlign: 'c',
                    tab: [{
                        title: '内嵌播放',
                        content: '<div style="margin:10px 30px 0 30px;display:flex"><div style="width:356px;display:inline-block;margin-left: -8px;height: 280px;overflow-y: scroll;" id="jiexilist">' +ListHtml.Insidehtml + '</div><div class="zhihu-scan" ><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>智狐百宝箱</h1><p>微信扫描上方二维码</p><p>关注我</p><p>从此不迷路</p></div></div>'
                    },
                          {
                              title: '跳转播放',
                              content: `<div style="margin:10px 30px 0 30px;display:flex"><div style="width:356px;display:inline-block;margin-left: -8px;height: 280px;overflow-y: scroll;" id="jiexilist">${ ListHtml.Outsidehtml}</div><div class="zhihu-scan" ><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>智狐百宝箱</h1><p>微信扫描上方二维码</p><p>关注我</p><p>从此不迷路</p></div></div>`
                          },
                          {
                              title: '解析设置',
                              content: `<div style="margin:10px 30px 0 30px;display:flex"><div style="width:356px;display:inline-block;padding-right: 15px;height: 280px;overflow-y: scroll;" id="jiexilist"><form class="zhihu-form" ><div class="zhihu-form-item"><label class="zhihu-form-label">解析接口</label><div class="zhihu-input-block"><select name="selectjiexi" lay-verify="required"  id ="selectjiexi"><option value="">直接选择或搜索选择</option>${ ListHtml.selecthtml}</select></div></div><div class="zhihu-form-item"><label class="zhihu-form-label">延迟时间</label><div class="zhihu-input-block"><input type="number" placeholder="${unsafeWindow.zhihu.Delaytime??3}" name="jiexitime" class="zhihu-input" style="display: inline-block;width: 100px;padding: 2px;margin-right: 10px;text-align: center;"><span style="font-size: 14px;color: #333;">秒</span></div></div><div class="zhihu-form-item"><label class="zhihu-form-label">自动解析</label><div class="zhihu-input-block"><input class="checkbox" type="checkbox" ${ jiexi} name="switch"  id="autoplay" ></div></div></form></div><div class="zhihu-scan" style="width:144px;"><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>智狐百宝箱</h1><p>微信扫描上方二维码</p><p>关注我</p><p>从此不迷路</p></div></div>`
                          }],
                    btn1: function(data) {
                        var s = data.getElementsByTagName('select');
                        for(let i= 0; i < s.length; i++ ){
                            let Index = s[i].selectedIndex;
                            let selectedid = s[i].options[Index].value;
                            let selecturl = s[i].options[Index].getAttribute("data-url");
                            commonFunction.setItem('selectedid', selectedid);
                            commonFunction.setItem('selecturl', selecturl);

                        }
                        var n = data.getElementsByTagName('input');
                        var time = unsafeWindow.zhihu.Delaytime??3
                        for(let i= 0; i <n.length; i++ ){
                            if(n[i].getAttribute("name") == "switch"){
                                let onswitch = document.querySelector("#autoplay+div").getAttribute("class");
                                if (onswitch.indexOf("zhihu-form-onswitch") != -1) {
                                    commonFunction.setItem('AutoPlay', '1');
                                    ControllerVideo.autoplay();
                                    commonFunction.Toast(time+'秒后自动解析视频',time*1000);
                                } else {
                                    commonFunction.setItem('AutoPlay', '0');
                                }
                            }else if(n[i].getAttribute("name") == "jiexitime"){
                                time = n[i].value;
                                if(time){
                                    commonFunction.setItem("Delaytime", time);
                                    unsafeWindow.zhihu.Delaytime = time;
                                }
                            }
                        }
                    }
                });
                if (commonFunction.getItem('selectid') != null) {
                    document.querySelector('#' + commonFunction.getItem('selectid')).className += " jiexiselect";
                }
                if (commonFunction.getItem('selectedid') != null) {
                    document.querySelector('#selectjiexi').value = commonFunction.getItem('selectedid');
                }
                var inList = document.getElementsByClassName('inside');
                for (var i = 0; i < inList.length; i++) {
                    inList[i].addEventListener('click',function() {
                        if (commonFunction.getItem('selectid') != null) {
                            document.querySelector('#' + commonFunction.getItem('selectid')).classList.remove("jiexiselect");
                        }
                        commonFunction.Toast('开始解析视频',2000);
                        var playObjecturl = this.getAttribute("data-url");
                        var playid = this.getAttribute("id");
                        console.log(playid);
                        commonFunction.setItem('selectid', playid);
                        console.log(commonFunction.getItem('selectid'));
                        this.className = "jiexi inside jiexiselect";
                        document.body.removeChild(document.querySelector(".zhihu-layer-tab"));
                        document.body.removeChild(document.querySelector(".zhihu-layer-shade"));
                        document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab"));
                        let url = playObjecturl + window.location.href;
                        console.log(url);
                        ControllerVideo.GoPlay(url);
                    });
                }

                var outList = document.getElementsByClassName('outside');
                console.log(outList);
                for (var u = 0; u < outList.length; u++) {
                    outList[u].addEventListener('click',
                                                function() {
                        let playObjecturl = this.getAttribute("data-url");
                        let Outsideurl = playObjecturl + window.location.href;
                        document.body.removeChild(document.querySelector(".zhihu-layer-tab"));
                        document.body.removeChild(document.querySelector(".zhihu-layer-shade"));
                        document.getElementsByTagName("head").item(0).removeChild(document.getElementById("tab"));
                        console.log(Outsideurl);
                        window.open(Outsideurl);
                    });
                }
            });
            //弹窗结束-----------------------------------------
            //自定义接口弹窗
            document.querySelector('#addjiexi').addEventListener('click',function() {
                let e = commonFunction.GMgetValue("userplayurl");
                console.log(e);
                if(e == null||e == ""||e == undefined){
                    let arr =[];
                    commonFunction.GMsetValue("userplayurl",arr);
                }
                let addListHtml = ControllerVideo.Videoaddlist();
                let addjiexihtml ="";
                addjiexihtml +='<form class="zhihu-form" style="height: 325px;margin: 10px 30px 0 30px;"><div style="width:520px;display:inline-block;height:280px;overflow-y: scroll;">'
                addjiexihtml +='<div class="zhihu-form-item"><textarea placeholder="B站,1,https://jx.m3u8.tv/jiexi/?url=&#10;B站,2,https://jx.m3u8.tv/jiexi/?url=&#10;分隔符使用英文逗号,解析名字:B站;1为内部播放,2为跳转播放,解析接口:https://jx.m3u8.tv/jiexi/?url=&#10;如需添加多个解析接口,每行设置一个" class="zhihu-input zhihu-unselect" style="min-height:100px;max-height:160px;max-width:512px;min-width:512px;padding: 10px;"></textarea>'
                addjiexihtml +='<ul class="addlist"><li><span>解析名称</span><span>播放类型</span><span class="urllist">接口地址</span><span>操作</span></li>'+addListHtml+'</ul></div></div>'
                addjiexihtml +='</form>'
                commonFunction.open({
                    area: ['580', '450'],
                    title: "添加解析接口",
                    shade: 0,
                    id:"",
                    btn: ['取消', '添加接口'],
                    content:addjiexihtml,
                    btn1: function(data) {
                        var s= data.getElementsByTagName('textarea');
                        for (var i = 0; i < s.length; i++) {
                            let jiexitext = s[i].value;
                            if(jiexitext){
                                let Alljiexitext = jiexitext.split(/[(\r\n)\r\n]+/); // 根据换行或者回车进行识别
                                Alljiexitext.forEach((item, index) => { // 删除空项
                                    if (!item) {
                                        Alljiexitext.splice(index, 1);
                                    }
                                })
                                Alljiexitext = Array.from(new Set(Alljiexitext)); // 去重
                                if(Alljiexitext){
                                    Alljiexitext.forEach((item, index) => {
                                        if (item) {
                                            let jiexiitem = item.split(/,/);
                                            let num = index+1
                                            if(jiexiitem.length == 3){
                                                if(jiexiitem[1]==1||jiexiitem[1]==2){
                                                    let j = {name:jiexiitem[0],category:jiexiitem[1],url:jiexiitem[2],showType:"1"};
                                                    let v= commonFunction.GMgetValue("userplayurl");
                                                    let l = v.push(j);
                                                    commonFunction.GMsetValue("userplayurl",v);
                                                    commonFunction.Toast("添加成功,请重新设置自动解析接口",1500)

                                                    console.log(v)
                                                }else{
                                                    commonFunction.Toast("第"+num+"行格式错误,请按照示例格式重新添加")
                                                }
                                            }else{
                                                commonFunction.Toast("第"+num+"行格式错误,请按照示例格式重新添加")
                                            }

                                        }
                                    })
                                }
                            }
                        }

                    }
                });
                var addurlList = document.getElementsByClassName('delurl');
                for (var u = 0; u < addurlList.length; u++) {
                    addurlList[u].addEventListener('click', function() {
                        let urlid = this.getAttribute("data-id");
                        let v= commonFunction.GMgetValue("userplayurl");
                        v.forEach((item, index) => {
                            if (index == urlid) {
                                v.splice(index, 1);
                            }
                        });
                        commonFunction.GMsetValue("userplayurl",v);
                        console.log(commonFunction.GMgetValue("userplayurl"));
                        commonFunction.Toast("删除成功,请重新设置自动解析接口",1500)
                        document.body.removeChild(document.querySelector(".zhihu-layer-page"));
                        document.body.removeChild(document.querySelector(".zhihu-layer-shade"));
                        document.getElementsByTagName("head").item(0).removeChild(document.getElementById("open"));
                        document.querySelector('#addjiexi').click();
                    });
                }
            });
        //自定义弹窗结束
        },
        //---------------------------------------------------------------------
        //手机端
        addmobbtn:async function() {
            await commonFunction.sleep(1000);
            if(config.host.indexOf("m.le.com")!=-1){
                var player = commonFunction.Commonsetinterval("#j-player");
                player.then(function(playernode){
                    playernode.style.display="block";
                });
                var vipLook = commonFunction.Commonsetinterval("#j-vipLook");
                vipLook.then(function(vipLooknode){
                    vipLooknode.parentNode.removeChild(vipLooknode);
                });
                var daoliu1 = commonFunction.Commonsetinterval(".daoliu1");
                daoliu1.then(function(daoliu1node){
                    daoliu1node.parentNode.removeChild(daoliu1node);
                });
            }
            var ListHtml = ControllerVideo.Videolist(playList);
            var offautohtml = '<span id="off">关闭自动解析</span><img src="">'
            var onautohtml = '<span id="on">开启自动解析</span><img src="">'
            var autohtml;
            if (commonFunction.getItem("AutoPlay") == 1) {
                autohtml = offautohtml
            } else {
                autohtml = onautohtml
            }
            var mainhtml = '<div class="mob-main"><div class="shaw"></div><div class="listmian"><div class="listmian-tit"><p>解析接口列表</p><div class="title_right" id="autobtn">' + autohtml + '</div></div><div class="list">' + ListHtml.mobhtml + '</div><p class="tips"><span class="ico">*</span><span>开启自动解析后,最后一次选择的接口即自动解析默认接口</span></p><p class="tips"><span class="ico">*</span><span>本脚本仅学习使用,解析接口收集于网络,版权问题联系接口制作者,请勿相信解析接口显示的任何广告</span></p></div></div>'
            var btnhtml = '<div><div class="elevator"><a class="elevator-msg" id="Showmain"><svg t="1651763850342" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2320" width="200" height="200"><path d="M661.333333 665.6l51.2 12.8 42.666667-72.533333-34.133333-38.4c4.266667-21.333333 4.266667-38.4 4.266666-55.466667s0-34.133333-4.266666-51.2l34.133333-38.4-42.666667-72.533333-51.2 12.8c-25.6-21.333333-55.466667-42.666667-89.6-51.2L554.666667 256h-85.333334l-17.066666 51.2c-34.133333 8.533333-64 25.6-89.6 51.2l-51.2-12.8-42.666667 72.533333 34.133333 38.4c-4.266667 21.333333-4.266667 38.4-4.266666 55.466667s0 34.133333 4.266666 51.2l-34.133333 38.4 42.666667 72.533333 51.2-12.8c25.6 21.333333 55.466667 42.666667 89.6 51.2L469.333333 768h85.333334l17.066666-51.2c34.133333-8.533333 64-25.6 89.6-51.2z m38.4 81.066667c-21.333333 17.066667-51.2 34.133333-76.8 42.666666L597.333333 853.333333h-170.666666l-25.6-64c-29.866667-12.8-55.466667-25.6-76.8-42.666666l-68.266667 12.8-85.333333-149.333334 42.666666-51.2V512c0-17.066667 0-29.866667 4.266667-42.666667l-42.666667-51.2 85.333334-149.333333 68.266666 12.8c21.333333-17.066667 51.2-34.133333 76.8-42.666667L426.666667 170.666667h170.666666l25.6 64c29.866667 12.8 55.466667 25.6 76.8 42.666666l68.266667-12.8 85.333333 149.333334-42.666666 51.2c4.266667 12.8 4.266667 29.866667 4.266666 42.666666s0 29.866667-4.266666 42.666667l42.666666 51.2-85.333333 149.333333-68.266667-4.266666zM512 554.666667c25.6 0 42.666667-17.066667 42.666667-42.666667s-17.066667-42.666667-42.666667-42.666667-42.666667 17.066667-42.666667 42.666667 17.066667 42.666667 42.666667 42.666667z m0 85.333333c-72.533333 0-128-55.466667-128-128s55.466667-128 128-128 128 55.466667 128 128-55.466667 128-128 128z" fill="#ffffff" p-id="2321"></path></svg><span class="">解析设置</span></a><a  id="playing" class="elevator-faq" target="_blank"><svg t="1651762741797" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1235" width="200" height="200"><path d="M512 853.333333c-187.733333 0-341.333333-153.6-341.333333-341.333333s153.6-341.333333 341.333333-341.333333 341.333333 153.6 341.333333 341.333333-153.6 341.333333-341.333333 341.333333z m0-85.333333c140.8 0 256-115.2 256-256s-115.2-256-256-256-256 115.2-256 256 115.2 256 256 256z m128-256l-213.333333 128V384l213.333333 128z" fill="#ffffff" p-id="1236"></path></svg><span class="">解析播放</span></a></div>' + mainhtml+'</div>';
            document.body.insertAdjacentHTML('afterbegin', btnhtml);
            var css = `body, html {
		         font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;
		    }
			.elevator {
				position: fixed;
				padding: 0 10px;
				top: 80%;
				margin-top: -140px;
				right: 10px;
				z-index: 899;
				background: rgb(64 64 64 / 81%);
				box-shadow: 1px 1px 8px 1px rgb(98 99 99 / 34%);
				border-radius: 30px;
			}

			.elevator a {
				position: relative;
				display: block;
				width: 26px;
				height: 56px;
				font-size: 22px;
				line-height: 20px;
				color: #b5b9bc;
				box-sizing: border-box;
				text-align: center;
			}

			.elevator a+a:after {
				position: absolute;
				top: 0;
				left: 50%;
				margin-left: -12px;
				content: '';
				width: 24px;
				border: 1px solid #F3F5F7;
			}

			.elevator a:hover {
				color: #14191e;
			}

			.elevator .icon {
				font-size: 24px;
				line-height: 56px;
				color: #199b6d;
				width: 28px;
				height: 28px;
				margin: 14px 0;
			}

			.elevator .icon:hover {
				color: #14191e;
			}

			.elevator a span {
				display: none;
				padding: 14px 0;
				font-size: 12px;
				color: #fff;
				line-height: 14px;
			}

			.elevator .elevator-msg:hover .icon,
			.elevator .elevator-faq:hover .icon, {
				display: none;
			}

			.elevator .elevator-msg:hover span,
			.elevator .elevator-faq:hover span, {
				display: inline-block;
			}
            .mob-main{
               display: none;
            }
            .shaw{
                  width: 100%;
                  height: 100%;
                  position: fixed;
                  top: 0;
                  left: 0;
                  z-index: 99998;
                  background: rgba(0,0,0,0.3);
            }
            .listmian{
                position: fixed;
                width:100%;
                height:400px;
				bottom: 0;
				z-index: 99999;
                border-radius: 14px 14px 0 0;
                background: #fff;
                box-shadow: 0 -8px 10px 0 rgba(0,0,0,.09);
               }
            .listmian-tit{
               background-color: #f5f5f5;
               height: 60px;
               position: relative;
               border-radius: 14px 14px 0 0;
            }
            .listmian-tit p {
               color: #222;
               font-size: 18px;
               font-weight: 600;
               margin-left: 20px;
               line-height: 60px;
               float: left;
            }
            .listmian-tit .title_right {
               float: right;
               margin-right: 20px;
               line-height: 60px;
             }
             .listmian-tit .title_right span{
               display: inline-block;
               color: #222;
               font-size: 14px;
               vertical-align: middle;
               font-weight: 900;
             }
             .title_right img{
                display: inline-block;
                width: 12px;
                height: 12px;
                margin-left: 3px;
                vertical-align: middle;
             }
             .list{
                margin: 10px 20px;
                display:flex;
                flex-direction: row;
                flex-wrap: wrap;
                justify-content: space-between;
                height: 240px;
                overflow-y: scroll;
                align-content: flex-start
             }
             .list span{
               display: inline-block;
               padding: 10px 5px;
               margin: 0 0 10px 0;
               background-color: #f6f8fa;
               border-radius: .07rem;
               min-width: 90px;
               text-align: center;
               font-size: 12px;
               line-height: 18px;
             }
             .jiexiselect{
             color: #fc5531;
             }
             .tips{
               margin: 5px 20px;
             }
             .tips span{
               font-size: 12px;
               font-weight: 700;
               color: #333;
               line-height: 14px;
             }
             .tips .ico{
               margin-right: 5px;
               color: #ff6022;
             }

          `;
            commonFunction.GMaddStyle(css);
            ControllerVideo.CheckAutoplay();
            if (commonFunction.getItem('selectid') != null) {
                document.querySelector('#' + commonFunction.getItem('selectid')).classList.add("jiexiselect");
            }

            document.querySelector('#playing').addEventListener('click',function() {
                ControllerVideo.autoplay();
                commonFunction.Toast('3秒后自动解析视频',3000);

            });
            document.querySelector('#Showmain').addEventListener('click',function() {
                document.querySelector(".mob-main").style.display = "block"
            });
            document.querySelector('.shaw').addEventListener('click',function() {
                document.querySelector(".mob-main").style.display = "none"
            })

            document.querySelector('#autobtn').addEventListener('click',function() {
                if (commonFunction.getItem('AutoPlay') == 1) {
                    this.innerHTML = onautohtml;
                    commonFunction.setItem('AutoPlay', '0');
                } else {
                    this.innerHTML = offautohtml;
                    commonFunction.setItem('AutoPlay', '1');
                    commonFunction.Toast('请选择自动解析接口',2000);
                };
            });
            var list = document.getElementsByClassName('mob-jiexi');
            for (var i in list) {
                list[i].addEventListener('click',function() {
                    commonFunction.Toast('开始解析视频',2000);
                    if (commonFunction.getItem('selectid') != null) {
                        document.querySelector('#' + commonFunction.getItem('selectid')).classList.remove("jiexiselect");
                    }
                    var playObjecturl = this.getAttribute("data-url");
                    var playid = this.getAttribute("id");
                    console.log(playid);
                    commonFunction.setItem('selectid', playid);
                    commonFunction.setItem('selecturl', playObjecturl);
                    this.classList.add("jiexiselect");
                    document.querySelector(".mob-main").style.display = "none";
                    let url = playObjecturl + window.location.href;
                    console.log(url);
                    ControllerVideo.GoPlay(url);
                })
            }
        },
        //---------------------------------------------------------------
        //检查自动播放
        CheckAutoplay:function(jiexitime) {
            if (commonFunction.getItem("AutoPlay") == 1) {
                ControllerVideo.autoplay();
                commonFunction.Toast(`${unsafeWindow?.zhihu?.Delaytime??3}'秒后自动解析视频`,`${unsafeWindow?.zhihu?.Delaytime??3}`*1000);

            }
        },
        //-----------------------------------------------------------------------
        //自动播放
        autoplay:async function(){
            await commonFunction.sleep(`${unsafeWindow?.zhihu?.Delaytime??3}`*1000);
            var f = "";
            var autoplayurl;
            if (commonFunction.getItem('selecturl') != null&&commonFunction.getItem('selecturl') != "null") {
                f = commonFunction.getItem('selecturl');
            }
            if (f != "") {
                autoplayurl = f + config.playhref;
            } else {
                let defurl = playList[0].url;
                console.log(defurl);
                autoplayurl = defurl + config.playhref;
            }
            ControllerVideo.GoPlay(autoplayurl);
        },
        //-------------------------------------------
        //执行播放
        GoPlay:function(e){
            var playurl = e;
            var PlayID = ControllerVideo.Playid();
            var iframeDivCss = "width:100%;height:100%;"
            if (config.host.indexOf("m.iqiyi.com") != -1) {
                iframeDivCss += "position: absolute;top: 0;right: 0;bottom: 0;left: 0;"
            }
            var videoPlayer = "<div style='" + iframeDivCss + "' id='zhihuplay'><iframe id='iframe-player-99087lkj' src='" + playurl + "' frameborder='0' allowfullscreen='true' width='100%' height='100%'></iframe></div>";
            var b = commonFunction.Videosetinterval(PlayID);
            b.then(function(Count){
                clearInterval(Count);
                document.querySelector(PlayID).innerHTML = "";
                document.querySelector(PlayID).innerHTML = videoPlayer;
            });
        }
    }
    //视频解析结束
    //优惠券开始
    var ControllerCoupon = {
        CouponidList:function(){
            var CouponidList = [
                { url:"item.taobao.com", qrname:"淘宝",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"},
                { url:"detail.tmall.com", qrname:"天猫",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"},
                { url:"detail.tmall.hk", qrname:"天猫",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"},
                { url:"chaoshi.detail.tmall.com", qrname:"天猫",nodeid:"#J_PromoPrice",goodid:commonFunction.Getgoodid("id"),method:"taobao",action:"getlink"},
                { url:"item.yiyaojd.com", qrname:"京东",nodeid:"#J-summary-top",goodid:commonFunction.geturlid(config.playhref),method:"jd",action:"getdetails"},
                { url:"item.jd.com", qrname:"京东",nodeid:"#J-summary-top",goodid:commonFunction.geturlid(config.playhref),method:"jd",action:"getdetails"},
                { url:"npcitem.jd.hk", qrname:"京东",nodeid:"#J-summary-top",goodid:commonFunction.geturlid(config.playhref),method:"jd",action:"getdetails"},
                { url:"s.taobao.com", qrname:"",nodeid:"pic-link",goodid:"",method:"",action:""},
                { url:"list.tmall.com", qrname:"",nodeid:"product",goodid:"",method:"",action:""},

            ];
            var Couponid = {};
            for(var i in CouponidList) { //获得窗口ID
                if (CouponidList[i].url == config.host) {
                    Couponid = {
                        qrname :CouponidList[i].qrname,
                        nodeid :CouponidList[i].nodeid,
                        goodid :CouponidList[i].goodid,
                        method :CouponidList[i].method,
                        action :CouponidList[i].action,
                    }
                    return Couponid
                    break;
                }
            }
            if(!Couponid){
                return;
            }
        },
        Getcoupon:function() {
            var Couponid = ControllerCoupon.CouponidList();
            console.log(Couponid)
            if (Couponid.goodid != "") {
                let headers ={
                    "Content-Type": "text/html; charset=utf-8"
                }
                var request = commonFunction.request("GET","http://tool.zhihupe.com/coupon/getcoupon.php?m=" + Couponid.method + "&act=" + Couponid.action + "&goodid=" + Couponid.goodid,headers);
                request.then(function(resdata){
                    if(resdata.result == "success"){
                        var json = JSON.parse(resdata.data);
                        var code = json.code;
                        if (Couponid.method == "taobao") {
                            if (code == "0") {
                                var longTpwd = json.data.longTpwd
                                var couponUrl = longTpwd.match(/https:\/\/[\d\w\.\/]+/)[0];
                                console.log(longTpwd);
                                console.log(couponUrl);
                                var couponInfo = json.data.couponInfo;
                                var couponEndTime = json.data.couponEndTime;
                                var actualPrice = json.data.actualPrice;
                                ControllerCoupon.addcoupon(Couponid,couponUrl, couponInfo, couponEndTime, actualPrice)
                            }else{
                                let u="",f="",t="",p="";
                                ControllerCoupon.addcoupon(Couponid,u, f, t, p);
                            }
                        } else if (Couponid.method == "jd") {
                            if (code == "0") {
                                var couponConditions = json.data[0].couponConditions;
                                var couponAmount = json.data[0].couponAmount;
                                var jdcouponInfo;
                                if (couponConditions != "") {
                                    jdcouponInfo = "满" + couponConditions + "元减" + couponAmount + "元"
                                } else {
                                    jdcouponInfo = "无门槛减" + couponAmount + "元"
                                }
                                var jdcouponEndTime = json.data[0].couponEndTime
                                var jdactualPrice = json.data[0].actualPrice;
                                var couponLink = json.data[0].couponLink;
                                ControllerCoupon.addcoupon(Couponid,couponLink, jdcouponInfo, jdcouponEndTime, jdactualPrice)
                            }else{
                                let u="",f="",t="",p="";
                                ControllerCoupon.addcoupon(Couponid,u, f, t, p);
                            }
                        }
                    }
                });
            } else {
                console.log('商品id为空!');
            }
        },
        addcoupon:function(Couponid,u, f, t, p) {
            var imgurl = "http://v.zhihupe.com/enQrcode?url=" + u
            var mainhtml,qa,cxalink,link;
            if(Couponid.qrname =="淘宝"){
                let ht = document.querySelector("#J_Title");
                qa = "淘宝";
                link ="http://tool.wezhicms.com/coupon/getscan.php?link="+u+"&goodid="+Couponid.goodid
                cxalink ='http://wxego.yhzu.cn/?r=/l&kw='+encodeURI(ht.querySelector("h3").innerText)+'&sort=0';
            }else if(Couponid.qrname =="天猫"){
                let hm = document.querySelector(".tb-detail-hd");
                cxalink ='http://wxego.yhzu.cn/?r=/l&kw='+encodeURI(hm.querySelector("h1").innerText)+'&sort=0';
                link ="http://tool.wezhicms.com/coupon/getscan.php?link="+u+"&goodid="+Couponid.goodid
                qa = "淘宝";
            }else if(Couponid.qrname =="京东"){
                cxalink = 'http://wxego.yhzu.cn/?r=/l/jdlist&kw='+encodeURI(document.querySelector(".sku-name").innerText)+'&sort=0';
                link = u
                qa = "京东";
            }

            if (f != "" && u != "") {
                mainhtml = '<div style="text-align: center;font-size: 14px;width: 25%;"><img style="width: 100%;height: auto;"src="' + imgurl + '"><p style="font-size: 12px;margin-top: 5px;">手机' + qa + '扫码领取</p></div><div style="width: 72%;"><p style="margin-bottom:10px;font-size: 18px;font-weight: 700;">优惠劵:' + f + '</p><p style="margin-bottom:10px;font-size: 14px;color:#999;">有效期至:' + t + '</p><div style="display: flex;justify-content: space-between;align-items: flex-start;"><div><span style="font-size:14px">劵后价:</span><span style="font-size: 18px;font-weight: 700;color: #F40;">¥</span><span style="font-size: 26px;font-weight: 700;font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;color: #F40;">' + p + '</span></div><a href="javascript:;" id="link"><span style="padding: 10px 20px;background-color: #df3033;font-size: 18px;color: #fff;font-weight: 700;">领券购买</span></a></div></div>'
            } else {
                mainhtml = '<div style="font-size: 18px;font-weight: 700;">暂无优惠券</div><a id="cxalink" href="javascript:;" style="background: #df3033;padding: 10px;color: #fff;font-size: 12px;">查询同款商品优惠</a>'
            }
            var couponhtml = '<div style="margin-top: 10px;background: #f1f1f100;padding: 15px 25px;display:flex;align-items: center;justify-content: space-between;margin-bottom:5px;font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;">' + mainhtml + '</div>';
            var Couponnodeid= commonFunction.Commonsetinterval(Couponid.nodeid);
            Couponnodeid.then(function(node){
                let b = document.createElement('div');
                b.innerHTML = couponhtml;
                if(unsafeWindow?.zhihu == true) return;
                node.parentNode.appendChild(b);
                unsafeWindow.zhihu = true;
                let linknode = document.querySelector("#link");
                if(linknode){
                    linknode.onclick = function() {
                        window.open(link);
                    };
                }
                let cxalinknode = document.querySelector("#cxalink");
                if(cxalinknode){
                    cxalinknode.onclick = function() {
                        window.open(cxalink);
                    };
                }
            });
        },
        //淘宝搜索页
        taobaoso:function(){
            var Couponid = ControllerCoupon.CouponidList();
            var Coupontbso= commonFunction.Commonsetinterval("."+Couponid.nodeid);
            Coupontbso.then(function(node){
                let a = document.getElementsByClassName(Couponid.nodeid);
                for (var i = 0; i < a.length; i++) {
                    let nid =a[i].getAttribute("data-nid");
                    let headers ={
                        "Content-type": "application/json"
                    }
                    var request = commonFunction.request("GET","http://v2.api.haodanku.com/item_detail?apikey="+config.hdapikey+"&itemid="+nid,headers);
                    request.then(function(resdata){
                        if(resdata.result == "success"){

                            let obj = JSON.parse(resdata.data);
                            console.log(obj);
                            if(obj.code ==1&&obj.data.couponmoney!=0){
                                let b = document.createElement('div');
                                b.style="position: absolute;top: 10px;right: 5px;font-size: 14px;font: 12px/1.5 PingFangSC-Regular,Helvetica,Arial,'Microsoft Yahei',sans-serif;z-index: 99999;";
                                b.innerHTML = '<span style="background: #F40;padding: 4px;color: #fff;border: 1px solid red;border-radius: 3px 0 0 3px;font-weight: bold;">券</span><span style="border: 1px solid #ff00001f;border-radius: 0 3px 3px 0;padding: 4px;color: #F40;background: #fff;">优惠'+obj.data.couponmoney+'元</span>';
                                document.querySelector("#J_Itemlist_PLink_"+nid).appendChild(b)
                            }
                        }
                    });
                }
            });
        },

        //天猫搜索页
        tmallso:function(){
            var Couponid = ControllerCoupon.CouponidList();
            var Coupontmso= commonFunction.Commonsetinterval("."+Couponid.nodeid);
            Coupontmso.then(function(node){
                let a = document.getElementsByClassName(Couponid.nodeid);
                ControllerCoupon.tmalllist(-1,a);
            });
        },
        tmalllist:function(i,a){
            setTimeout(function(){
                if(++i < a.length){
                    let nid =a[i].getAttribute("data-id");
                    var m = document.getElementsByClassName("product")[i];
                    let headers ={
                        "Content-type": "application/json"
                    }
                    var request = commonFunction.request("GET","http://v2.api.haodanku.com/item_detail?apikey="+config.hdapikey+"&itemid="+nid,headers);
                    request.then(function(resdata){
                        if(resdata.result == "success"){
                            let obj = JSON.parse(resdata.data);
                            if(obj.code ==1&&obj.data.couponmoney!=0){
                                let b = document.createElement('div');
                                b.style="position: absolute;top: 10px;right: 5px;font-size: 14px;font: 12px/1.5 PingFangSC-Regular,Helvetica,Arial,'Microsoft Yahei',sans-serif;z-index: 99999;";
                                b.innerHTML = '<span style="background: #F40;padding: 4px;color: #fff;border: 1px solid red;border-radius: 3px 0 0 3px;font-weight: bold;">券</span><span style="border: 1px solid #ff00001f;border-radius: 0 3px 3px 0;padding: 4px;color: #F40;background: #fff;">优惠'+obj.data.couponmoney+'元</span>';
                                console.log(obj.data.couponmoney);
                                m.appendChild(b);
                            }
                            ControllerCoupon.tmalllist(i,a);
                        }
                    });
                }
            }, Math.random() * 10);
        },
    }
    //优惠券结束
    //历史价格查询开始
    var ControllerHistory ={
        History:function(){
            var Couponid = ControllerCoupon.CouponidList();
            var gid = Couponid.goodid;
            let HistoryHtml ='<div style="font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif!important;"><div style="font-size: 18px;font-weight: bold;margin: 0px;text-align: center;">商品历史价格对比查询</div><div id="history"><div><div id="historyhead" style="font-size: 14px;text-align: center;margin-top: 10px;"></div></div><div style="height:400px;" id="container"><span style="text-align: center;font-size: 24px;font-weight: bold;margin: 0 auto;display: block;line-height: 400px;">数据查询中,请稍后...</span></div></div>'
            var goodurl,Historynode;
            if(Couponid.method == "taobao"){
                if(config.host.indexOf("taobao")!=-1){
                    goodurl ="https://detail.tmall.com/item.htm?id=" + gid;
                }else{
                    goodurl ="https://"+config.host+"/item.htm?id=" + gid;
                }
                Historynode = "#detail";
            }else if(Couponid.method == "jd"){
                goodurl ="https://item.jd.com/"+ gid+".html";
                Historynode = ".product-intro"
            }
            var addHistory= commonFunction.Commonsetinterval(Historynode);
            addHistory.then(function(node){
                let b = document.createElement('div');
                b.style = "padding:20px;border: 1px solid #eee;margin: 10px auto;position: relative;clear: both;"
                b.innerHTML = HistoryHtml;
                node.appendChild(b);
                ControllerHistory.getHistory(goodurl);
            });
        },

        getHistory:function(goodurl){
            let headers ={
                'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36',
                'Accept-Language': 'zh-CN,zh;q=0.9',
                'Content-Type': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
                'sec-ch-ua-platform': 'Windows',
                'Sec-Fetch-Mode': 'cors',
                'Sec-Fetch-Dest': 'empty',
                'Sec-Fetch-Site': 'same-origin',
                'Accept-Encoding': 'gzip, deflate, br',
                'Sec-Fetch-User': '?1',
                'Connection': 'keep-alive',
                'Host': 'bijiatool-v2.manmanbuy.com',
            }
            var request = commonFunction.request("POST","https://bijiatool-v2.manmanbuy.com/ChromeWidgetServices/WidgetServices.ashx?methodName=getBiJiaInfo&jsoncallback=&p_url=" + goodurl,headers);
            request.then(function(resdata){
                if(resdata.result == "success"){
                    let obj = JSON.parse(resdata.data);
                    if(obj.jiagequshi ==undefined||obj.jiagequshiyh ==""){
                        document.querySelector("#history").innerHTML='<div style="text-align: center;margin: 20px 0;font-size: 14px;">暂未收录</div>';
                    }else{
                        let headhtml ='<div> 历史最低价格 <span  style="margin-right: 20px;">'+obj.lowerPriceyh+'元</span><span  style="margin-right: 20px;">数据来源于网络,仅供参考</span> </div>'
                        document.querySelector("#historyhead").innerHTML =headhtml;
                        ControllerHistory.Showchart(obj);
                    }
                }
            });
        },
        Showchart:function(obj){
            var strDate = obj.jiagequshiyh;
            var chartDom = document.getElementById('container');
            var myChart = echarts.init(chartDom);
            var option;
            var oldData = [];
            var data = [];
            var currentDay = new Date().setHours(0, 0, 0, 0);
            var currentDayDate = new Date(currentDay).getTime();
            var minMonth =4,xBlockNum=6;
            oldData = eval("([" + strDate + "])");
            for (var i = 1; i < oldData.length; i++) {
                var key = oldData[i][0];
                var j = i - 1;
                while (j >= 0 && oldData[j][0] > key) {
                    oldData[j + 1] = oldData[j];
                    j--;
                }
                oldData[j + 1][0] = key;
            }
            var xInterval, yInterval, yMin, yMax, xMin, xMax, maxValue, minValue, maxDate, minDate, addDate;
            addDate = minMonth * 30 * 24 * 60 * 60 * 1000; //日期不足三个月,补到120天
            var arrX = [], arrY = [];
            console.log(oldData);
            for (var l = 0; l < oldData.length;l++) {
                if (oldData[l][1] <= 0) continue;
                arrX.push(oldData[l][0]);
                arrY.push(oldData[l][1]);
                data.push([oldData[l][0], oldData[l][1],oldData[l][2]]);
            }
            console.log(oldData);
            if (data.length > 0 && data[data.length - 1][0] < currentDayDate) {
                data.push([currentDayDate, data[data.length - 1][1], ""]);
            }
            maxValue = Math.max.apply(null, arrY); //y轴最大值
            minValue = Math.min.apply(null, arrY); //y轴最小值
            maxDate = new Date(data[data.length - 1][0]).getTime(); //最大日期
            minDate = new Date(data[0][0]).getTime(); //最小日期

            yMin = minValue - ((minValue + maxValue) / 2 - minValue); //y轴开始最小值
            yMin = yMin >= 0 ? yMin : 0;
            yMax = maxValue + (maxValue - minValue) / 4;
            if (yMax === yMin) {
                yMin = yMin - yMin / 2;
                yMax = yMax + yMax / 2;
            }
            if (maxDate - minDate > addDate) {
                xMin = minDate;
            } else {
                xMin = maxDate - addDate; //往前补四个月
            }
            xMax = maxDate;
            xInterval = (xMax - xMin) / xBlockNum;
            yInterval = (yMax - yMin) / xBlockNum;
            console.log(arrX );

            option = {
                animation: false,
                tooltip: {
                    trigger: 'axis',
                    transitionDuration: 0,
                    confine: true,
                    backgroundColor: 'transparent',
                    padding: 0,
                    borderWidth: 0,
                    borderColor: '#ec652e',
                    position: function (point, params, dom) {
                        var width = dom.clientWidth;
                        return [point[0] - width / 2, 0];
                    },
                    formatter: function (obj) {
                        if (obj.length > 0) {
                            var timeArr = ControllerHistory.getLocalTime(obj[0].data[0]).split('-');
                            var time = timeArr[0] + '年' + timeArr[1] + '月' + timeArr[2] + '日';
                            var minPrice = obj[0].data[1];
                            var youhui = obj[0].data[2];
                            for (var i = 1; i < obj.length; i++) {
                                if (obj[i].data[1] < minPrice) {
                                    minPrice = obj[i].data[1];
                                    youhui = obj[i].data[1];
                                }
                            }

                            var retHTML = '<div style="border-radius:10px;padding:0 10px;height:22px;line-height:22px;background:#ec652e; color:#ffffff; font-size:11px;">' + time + '&nbsp;&yen;' + minPrice + '</div>';
                            if (youhui.length > 0) {

                                retHTML = '<div style="border-radius:10px;padding:0 10px;height:44px;line-height:22px;background:#ec652e; color:#ffffff; font-size:11px;">' + time + '&nbsp;&yen;' + minPrice + "<br/>" + youhui + '</div>';
                            }
                            var curDate = new Date();
                            var vDate = new Date(obj[0].data[0]);
                            if (obj[0].dataIndex === 0 && vDate > new Date(curDate.getTime() - 24 * 60 * 60 * 1000 * 25 * 30)) {
                                if (youhui.length > 0) {
                                    retHTML = '<div style="border-radius:10px;padding:0 10px;height:22px;line-height:44px;background:#ec652e; color:#ffffff; font-size:11px;">第一次收录&nbsp;' + time + '&nbsp;&yen;' + minPrice + "<br/>" + youhui + '</div>';
                                }
                                else {
                                    retHTML = '<div style="border-radius:10px;padding:0 10px;height:22px;line-height:22px;background:#ec652e; color:#ffffff; font-size:11px;">第一次收录&nbsp;' + time + '&nbsp;&yen;' + minPrice + '</div>';
                                }
                            }
                            return retHTML;
                        }
                    },
                    axisPointer: {
                        type: 'line',
                        lineStyle: {
                            color: '#ec652e'
                        }
                    }
                },
                grid: {
                    left: "3%",
                    right: "3%",
                    bottom: "3%",
                    top: 20,
                    containLabel: true
                },
                xAxis: {
                    type: 'time',
                    axisTick: {
                        show: false
                    },
                    axisLine: {
                        lineStyle: {
                            color: '#dddddd'
                        }
                    },
                    interval: xInterval,
                    boundaryGap: false,
                    align: 'right',
                    axisLabel: {
                        align: 'right',
                        rotate: 0,
                        color: '#555555',
                        showMinLabel: true,
                        showMaxLabel: true,
                        formatter: function (value, index) {
                            var date = new Date(value);
                            //var texts = [(date.getMonth() + 1) > 9 ? (date.getMonth() + 1) : ('0' + (date.getMonth() + 1)), date.getDate() > 9 ? date.getDate() : ('0' + date.getDate())];
                            var texts = [(date.getMonth() + 1), date.getDate()];
                            if (index === 0) {
                                texts = [''];
                            } else if (index === (arrX.length - 1)) {
                                //texts.unshift(date.getFullYear());
                            } else {
                                //texts = [''];
                            }

                            return texts.join('-');
                        }
                    },
                    splitLine: {
                        show: true,
                        lineStyle: {
                            color: ['#ddd'],
                            type: 'solid',
                            opacity: .8
                        }
                    },
                    min: function (value) {
                        return xMin;
                    },
                    max: function (value) {
                        return xMax;
                    }
                },
                yAxis: {
                    type: 'value',
                    axisTick: {
                        show: false
                    },
                    interval: yInterval,
                    boundaryGap: false,
                    scale: true,
                    axisLabel: {
                        show: true,
                        inside: false,
                        showMinLabel: true,
                        showMaxLabel: true,
                        color: '#555',
                        formatter: function (value, index) {
                            if (index === 0) {
                            } else {
                                return value.toFixed(0);
                            }
                        }
                    },
                    axisLine: {
                        lineStyle: {
                            color: '#dddddd'
                        }
                    },
                    splitLine: {
                        show: true,
                        lineStyle: {
                            color: ['#ddd'],
                            type: 'solid',
                            opacity: .8
                        }
                    },
                    //最小刻度
                    min: function (value) {
                        return yMin;
                    },
                    max: function (value) {
                        return yMax;
                    }
                },
                series: [{
                    name: '价格',
                    type: 'line',
                    symbol: 'circle',
                    symbolSize: [2, 2],
                    showSymbol: false,
                    itemStyle: {
                        color: '#ff6729'
                    },
                    lineStyle: {
                        width: 2,
                        shadowColor: '#dddddd',
                        shadowBlur: 0,
                        shadowOffsetY: 0.3,
                        shadowOffsetX: 0,
                        z: 22
                    },
                    markLine: {
                        silent: true,
                        symbol: 'none',
                        data: [{
                            type: 'max',
                            symbol: 'none',
                            lineStyle: {
                                color: '#888888',
                                type: 'dotted',
                                width: 0.8
                            },
                            label: {
                                position: 'end',
                                formatter: '{c}',
                                color: 'transparent'
                                //color: '#555555'
                            }
                        }, {
                            type: 'min',
                            symbol: 'none',
                            lineStyle: {
                                color: '#888888',
                                type: 'dotted',
                                width: 0.8
                            },
                            label: {
                                position: 'end',
                                formatter: '{c}',
                                color: '#555555'
                            }
                        }],
                        label: {
                            show: true,
                            position: 'left'
                        }
                    },
                    data: data
                }],
            };

            if (maxDate - minDate < addDate) {
                var lineDash = [{
                    coord: [xMin, arrY[0]],
                    lineStyle: {
                        width: 1.3
                    }
                }, {
                    coord: [arrX[0], arrY[0]]
                }];
                option.series[0].markLine.data.push(lineDash)
            }

            myChart.clear();
            myChart.setOption(option, true);
            myChart.dispatchAction({
                type: 'showTip',
                seriesIndex: 1,
                dataIndex: 1
            })
        },
        getLocalTime:function(nS) {
            var year = new Date(parseInt(nS)).getFullYear();
            var mouth = new Date(parseInt(nS)).getMonth() + 1;
            mouth = mouth < 10 ? '' + mouth : mouth;
            var day = new Date(parseInt(nS)).getDate() < 10 ? '' + new Date(parseInt(nS)).getDate() : new Date(parseInt(nS)).getDate();
            return year + '-' + mouth + '-' + day;
        },

    }
    //历史价格查询结束
    //短视频下载开始
    var ControllerShortvideo ={
        ShortvideoidList:function(){
            var ShortvideoidList = [
                { url:"www.douyin.com", videoid:commonFunction.geturlid(config.playhref),nodeid:".xg-right-grid"},
                { url:"www.kuaishou.com", videoid:commonFunction.geturlid(config.playhref),nodeid:".right"},
                { url:"www.ixigua.com", videoid:commonFunction.geturlid(config.playhref),nodeid:".xg-right-grid"},

            ];
            var Shortvideoid = {};
            for(var i in ShortvideoidList) { //获得窗口ID
                if (ShortvideoidList[i].url == config.host) {
                    Shortvideoid = {
                        videoid :ShortvideoidList[i].videoid,
                        nodeid :ShortvideoidList[i].nodeid
                    }
                    return Shortvideoid
                    break;
                }
            }
            if(!Shortvideoid){
                return;
            }
        },
        ToastDwon:function(videourl,filename,mode) {
            var m = document.createElement('div');
            m.innerHTML ='<h3 style="text-align: center;margin: 15px 0;font-size: 18px;font-weight: bold;"> 下载视频 </h3><div style="word-break: break-all;padding: 10px;background: #f1f1f1; font-size: 12px; height: 100px;overflow-y: scroll;box-sizing: border-box;margin-bottom: 10px;border-radius: 5px;"><p>'+videourl+'</p> </div><div style="display: flex;float: right;font-size: 14px;"><div id="close" style="margin-right: 15px;">关闭</div> <div> <a  id="videofile">下载</a></div></div><div style="float: left;font-size: 14px;"><div> <a href="'+videourl+'" target="_blank">浏览器打开</a></div></div>';
            m.setAttribute('id','dwon');
            m.style.cssText = "max-width: 480px;min-width: 150px;padding: 0 25px;height: 200px;color: #323442;line-height: 20px;border-radius: 4px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 999998;background: #fff;font-size: 16px;box-shadow: 1px 1px 50px rgb(0 0 0 / 40%);font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;";
            document.body.appendChild(m);
            document.querySelector("#close").addEventListener('click',function() {
                document.body.removeChild(document.querySelector("#dwon"))
            })
            document.querySelector("#videofile").addEventListener('click',function() {
                commonFunction.Toast("创建下载需要时间,长时间未创建,点击浏览器打开,右键另存为",4000);
                if(mode ==1){
                    GM_download({
                        url:videourl+'.mp4',
                        name: filename,
                        saveAs: true, //布尔值,显示"保存为"对话框
                        onerror: function (error) {
                            commonFunction.Toast("下载出错,点击浏览器打开手动保存",3000)
                        },
                        onprogress: (pro) => {
                        },
                        ontimeout: () => {
                            //如果此下载由于超时而失败,则要执行的回调
                            commonFunction.Toast("下载超时,点击浏览器打开手动保存",3000)
                        },
                        onload: () => {
                            commonFunction.Toast(filename+"下载完成",3000)
                        }
                    })
                }else{
                    fetch(videourl+'.mp4').then(res => res.blob()).then(blob => {
                        const a = document.createElement('a');
                        document.body.appendChild(a)
                        a.style.display = 'none'
                        const url = window.URL.createObjectURL(blob);
                        a.href = url;
                        a.download = filename;
                        a.click();
                        document.body.removeChild(a)
                        window.URL.revokeObjectURL(url);
                    });
                }
            })
        },//公共下载弹窗结束
        //抖音下载开始
        douyinbtn:function() {
            var Shortvideoid = ControllerShortvideo.ShortvideoidList();
            let downhtml = '<div class="xgplayer-icon"><div class="xgplayer-setting-label"><span class="xgplayer-setting-title">下载</span></div></div>';
            var douyin= commonFunction.Commonsetinterval(Shortvideoid.nodeid);
            douyin.then(function(node){
                var b = document.createElement('xg-icon');b.innerHTML = downhtml;
                b.setAttribute("class","xgplayer-autoplay-setting automatic-continuous");
                b.setAttribute("id","downvideo");
                node.appendChild(b);

                ControllerShortvideo.getdouyinvideo(Shortvideoid.videoid);
            });
        },
        getdouyinvideo:function(d){
            document.querySelector('#downvideo').addEventListener('click',function() {
                commonFunction.Toast("正在获取视频文件",3000)
                if (d != "") {
                    var request = commonFunction.request("GET","https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids=" + d,null,null);
                    request.then(function(resdata){
                        if(resdata.result == "success"){
                            var json=JSON.parse(resdata.data);
                            console.log(json)
                            if(json.status_code==0){
                                let vid = json.item_list[0].video.vid;
                                if(vid){
                                    var filename = d+".mp4";
                                    var url = "https://aweme.snssdk.com/aweme/v1/play/?video_id="+vid+"&ratio=1080p&line=0";
                                    commonFunction.Toast("视频获取成功",3000)
                                    ControllerShortvideo.ToastDwon(url,filename,1);
                                }else{
                                    commonFunction.Toast("视频文件获取失败",3000)
                                }
                            }
                        }
                    });
                } else {
                    console.log('视频id为空!');
                }
            });
        },//抖音下载结束
        //快手下载开始
        kuaishoubtn:function() {
            var Shortvideoid = ControllerShortvideo.ShortvideoidList();
            var kuaishou= commonFunction.Commonsetinterval(Shortvideoid.nodeid);
            kuaishou.then(function(node){
                var b = document.createElement('div');
                b.innerHTML = '<div>下载</div>';
                b.setAttribute("class","kwai-player-volume-container player-bar-volume show-volume-slide");
                b.setAttribute("data-v-0c78ed39","");
                b.setAttribute("data-v-5037d859","");
                b.setAttribute("data-v-2475c26c","");
                b.setAttribute("data-v-56544f8e","");
                b.setAttribute("id","downvideo");
                node.insertBefore(b,node.childNodes[0]);
                if(config.playhref.indexOf("short-video")!=-1){
                    var e = document.querySelector(".total")
                    e.style.right ="180px"
                    var f = document.querySelector(".player-bar-progress")
                    f.style.width ="calc(100% - 318px)";
                }
                ControllerShortvideo.getksvideo(Shortvideoid.videoid)
            });
        },
        getksvideo:function(d){
            document.querySelector('#downvideo').addEventListener('click',function() {
                commonFunction.Toast("正在获取视频文件",1000)
                let videonode = document.querySelector("video")
                let src =videonode.getAttribute("src")
                let pausebtn = document.querySelector(".pause-icon");
                if(pausebtn != null){
                    pausebtn.click();
                }

                if(src.indexOf("blob:") != -1){
                    let params ='{"operationName":"visionVideoDetail","variables":{"photoId":"'+d+'","page":"detail"},"query":"query visionVideoDetail($photoId: String, $type: String, $page: String, $webPageArea: String) {\\n  visionVideoDetail(photoId: $photoId, type: $type, page: $page, webPageArea: $webPageArea) {\\n    status\\n    type\\n    author {\\n      id\\n      name\\n      following\\n      headerUrl\\n      __typename\\n    }\\n    photo {\\n      id\\n      duration\\n      caption\\n      likeCount\\n      realLikeCount\\n      coverUrl\\n      photoUrl\\n      liked\\n      timestamp\\n      expTag\\n      llsid\\n      viewCount\\n      videoRatio\\n      stereoType\\n      croppedPhotoUrl\\n      manifest {\\n        mediaType\\n        businessType\\n        version\\n        adaptationSet {\\n          id\\n          duration\\n          representation {\\n            id\\n            defaultSelect\\n            backupUrl\\n            codecs\\n            url\\n            height\\n            width\\n            avgBitrate\\n            maxBitrate\\n            m3u8Slice\\n            qualityType\\n            qualityLabel\\n            frameRate\\n            featureP2sp\\n            hidden\\n            disableAdaptive\\n            __typename\\n          }\\n          __typename\\n        }\\n        __typename\\n      }\\n      __typename\\n    }\\n    tags {\\n      type\\n      name\\n      __typename\\n    }\\n    commentLimit {\\n      canAddComment\\n      __typename\\n    }\\n    llsid\\n    danmakuSwitch\\n    __typename\\n  }\\n}\\n"}';
                    let headers = {
                        "Content-type": "application/json"
                    };
                    var request = commonFunction.request("POST","https://www.kuaishou.com/graphql",headers,params);
                    request.then(function(resdata){
                        if(resdata.result == "success"){
                            let obj=JSON.parse(resdata.data);
                            let src=obj.data.visionVideoDetail.photo.photoUrl;
                            commonFunction.Toast("视频获取成功",1000)
                            ControllerShortvideo.ToastDwon(src,d,"")
                        }
                    })
                }else{
                    commonFunction.Toast("视频获取成功",1000)
                    ControllerShortvideo.ToastDwon(src,d,"")
                }
            })
        },
        //快手下载结束
        //西瓜视频下载开始
        xiguabtn:function() {
            var Shortvideoid = ControllerShortvideo.ShortvideoidList();
            var xigua= commonFunction.Commonsetinterval(Shortvideoid.nodeid);
            xigua.then(function(node){
                let btnHTML = '<div id="downvideo" class="playerControlsItemContainer" ><div class="xgplayer-control-item control_definition common-control-item"><div class="xgplayer-control-item__entry"><div class="xgpcPlayer_textEntry"><span>下载</span></div></div></div></div>';
                node.insertAdjacentHTML('afterbegin', btnHTML);
                ControllerShortvideo.getxgvideo(Shortvideoid.videoid)
            });
        },
        getxgvideo:function(d){
            document.querySelector('#downvideo').addEventListener('click',function() {
                commonFunction.Toast("正在获取视频文件",1000);
                let headers = {
                    "Content-type": "application/json"
                };
                let request = commonFunction.request("POST","http://47.99.158.118/video-crack/v2/parse?content="+config.playhref,headers,null);
                request.then(function(resdata){
                    if(resdata.result == "success"){
                        let obj=JSON.parse(resdata.data);
                        if(obj.code == 0){
                            commonFunction.Toast("视频获取成功",1000)
                            ControllerShortvideo.ToastDwon(obj.data.url,d)
                        }else {
                            commonFunction.Toast("此视频不支持解析")
                        }
                    }
                })
            })
        }
        //西瓜视频下载结束

    }
    //短视频下载结束
    //aria2设置开始
    var Controlleraria2 = {
        aria2set:function(b){
            let css= `
            .layui-form{
             display: flex;
             margin-top: 20px;
             }
             .layui-form-label {
               box-sizing: content-box;
             }
             .layui-input-block p{
              font-size:12px
             }
             .layui-form-item{
             margin-bottom:5px
             }
             .layui-input-block{
             min-height:auto;
             }
            .main-left{
              width: 367px;
            }
            .zhihu-scan{
               width:180px;
			   display:inline-block;
			   text-align: center;
               margin-right: 40px;
            }
			.zhihu-scan img{
				width: 140px;
				margin: 0 5px 10px 5px;
			}
			.zhihu-scan h1{
				font-size: 18px;
				font-weight: bold;
				margin: 0px 0 20px 0;
			}
			.zhihu-scan p{
			  margin: 0;
			  color: #666;
			  font-size: 14px;
			}
         `;
            commonFunction.GMaddStyle(css);
            document.querySelector("#aria2set") .addEventListener('click',function() {
                let rpc="ws://localhost:6800/jsonrpc";
                if(commonFunction.getItem("rpc")!=null){
                    rpc= commonFunction.getItem("rpc")
                }
                let token="";
                if(commonFunction.getItem("token")!=null){
                    token= commonFunction.getItem("token")
                }
                let mulu="D:/";
                if(commonFunction.getItem("mulu")!=null&&commonFunction.getItem("mulu")!=""){
                    mulu= commonFunction.getItem("mulu")
                }
                let plcode="";
                if(commonFunction.getItem("plcode")!=null){
                    plcode= commonFunction.getItem("plcode")
                }
                let contenthtml ="";
                contenthtml +='<form class="zhihu-form" style="height: 325px;"><div class="main-left">'
                contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">RPC地址</label><div class="zhihu-input-inline"><input name="rpc" value="'+rpc+'"  placeholder="" class="zhihu-input"></div></div>'
                contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>Aria2配置:ws://localhost:6800/jsonrpc<br>Motrix配置:ws://localhost:16800/jsonrpc</p></div></div>'
                contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">token</label><div class="zhihu-input-inline"><input name="token" value="'+token+'"  placeholder="" class="zhihu-input"></div></div>'
                contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>没有请留空</p></div></div>'
                contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">保存地址</label><div class="zhihu-input-inline"><input name="mulu" value="'+mulu+'"  placeholder="留空使用默认目录" class="zhihu-input"></div></div>'
                contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>留空使用默认目录</p></div></div>'
                contenthtml +='<div class="zhihu-form-item"> <label class="zhihu-form-label">验证码</label><div class="zhihu-input-inline"><input name="plcode" value="'+plcode+'"  placeholder="请输入验证码" class="zhihu-input"></div></div>'
                contenthtml +='<div class="zhihu-form-item" style="color: #acaeb5;"><div class="zhihu-input-block"><p>批量下载需要关注公众号</p></div></div>'
                contenthtml +='</div><div class="zhihu-scan"><img src="http://cdn.wezhicms.com/uploads/allimg/20211215/1-21121500044Q94.jpg"><h1>验证码获取</h1>'
                contenthtml +='<div style="font-size: 12px;color: #000;margin-left:15px;text-align: left;"><div style="line-height: 3;">1.关注公众号【智狐百宝箱】</div><div style="line-height: 2;">2.回复大写字母‘B’获取验证码</div><div style="line-height: 3;">3.将验证码输入左边输入框中</div></div></div></form>'
                commonFunction.open({
                    area: ['580', '450'],
                    title: "批量下载设置",
                    shade: 0,
                    id:"biliset",
                    btn: ['取消', '保存设置'],
                    content:contenthtml,
                    btn1: function(data) {
                        var n = data.getElementsByTagName('input');
                        for(let i= 0; i <n.length; i++ ){
                            if (n[i].getAttribute("name") == "rpc") {
                                commonFunction.setItem("rpc",n[i].value);
                            }
                            else if (n[i].getAttribute("name") == "token") {
                                commonFunction.setItem("token",n[i].value);
                            }
                            else if (n[i].getAttribute("name") == "mulu") {
                                commonFunction.setItem("mulu",n[i].value);
                            }
                            else if (n[i].getAttribute("name") == "plcode") {
                                if(n[i].value != ""){
                                    commonFunction.setItem("plcode",n[i].value);
                                }else{
                                    commonFunction.setItem("plcode","");
                                    commonFunction.Toast('请在脚本设置里输入验证码!');
                                }
                            }
                        }
                    }
                });
            });
            document.querySelector("#all") .addEventListener('click',function() {

                b.forEach(function(element) {
                    element.checked = true;

                })
                commonFunction.Toast("已经全部选择",3000)
            });
            document.querySelector("#delall") .addEventListener('click',function() {

                b.forEach(function(element) {
                    element.checked = false;
                });
                commonFunction.Toast("已经全部取消选择",3000)
            });
        },
        addUri:function(u,t) {
            //配置
            return new Promise(function(resolve, reject) {
                var wsurl = commonFunction.getItem("rpc");;
                var uris = [u];
                var token="";
                var filename = t
                if(commonFunction.getItem("mulu")!=null&&commonFunction.getItem("mulu")!=""){
                    var mulu= commonFunction.getItem("mulu")
                    }else{
                        mulu ="D:/"
                    }
                var options = {
                    "dir":mulu,
                    "max-connection-per-server": "16",
                    "header": [ "User-Agent: "+config.UA, "Referer: "+config.playhref ]
                };
                if (filename != "") {
                    options.out = filename;
                }
                var json = {
                    "id": "zhihu",
                    "jsonrpc": '2.0',
                    "method": 'aria2.addUri',
                    "params": [uris, options],
                };
                console.log(json)
                if (token != "") {
                    json.params.unshift("token:" + token); // 坑死了,必须要加在第一个
                }
                var ws = new WebSocket(wsurl);

                ws.onerror = event => {
                    console.log(event);
                    commonFunction.Toast('连接错误, Aria2 连接错误,请检查RPC设置!');
                };
                ws.onopen = () => { ws.send(JSON.stringify(json)); }

                ws.onmessage = event => {
                    let received_msg = JSON.parse(event.data);
                    console.log(received_msg);
                    if (received_msg.error !== undefined) {
                        if (received_msg.error.code === 1)commonFunction.Toast('通过RPC连接失败', '请打开控制台查看详细错误信息,返回信息:' + received_msg.error.message);
                    }
                    resolve();
                    switch (received_msg.method) {
                        case "aria2.onDownloadStart":
                            commonFunction.Toast("Aria2 发送成功, "+filename+" 已经开始下载!",1000);
                            ws.close();
                            break;
                        default:
                            break;
                    }
                };
            });
        },
        plaria2:function(i,arr){
            setTimeout(function(){
                if(++i < arr.length){
                    Controlleraria2.addUri(arr[i].url,arr[i].title)
                    Controlleraria2.plaria2(i,arr);
                    console.log(i,arr.length)
                }
            }, Math.random() * 1000);

        }
    };
    //aria2设置结束
    //Bilibili下载开始
    var ControllerBilibili ={
        Addlist:async function(){
            const listHtml = ()=>{
                var Bilihtml="";
                var episodes = unsafeWindow?.__INITIAL_STATE__?.sections[0]?.episodes;
                if(!episodes){
                    let aid = unsafeWindow?.__INITIAL_STATE__?.videoData?.aid;
                    if(!aid)return;
                    let videolist = unsafeWindow?.__INITIAL_STATE__?.videoData?.pages;
                    for (let i = 0; i < videolist.length; i++) {
                        Bilihtml += '<li><a href="javascript:void(0)" class="router-link-active" ><div class="clickitem"><div class="link-content"><input  data-aid="'+aid+'" data-cid="'+videolist[i].cid+'" title="'+videolist[i].part+'" type="checkbox" style="margin-right:5px"> <span class="page-num">P'+videolist[i].page+'</span><span class="part">'+videolist[i].part+'</span></div><div class="duration bilidown" data-aid="'+aid+'" data-cid="'+videolist[i].cid+'" title="'+videolist[i].part+'">下载</div></div></a></li>';
                    }
                }else {
                    for (let i = 0; i < episodes.length; i++) {
                        Bilihtml += '<li><a href="javascript:void(0)" class="router-link-active" ><div class="clickitem"><div class="link-content"><input  data-aid="'+episodes[i].aid+'" data-cid="'+episodes[i].cid+'" title="'+episodes[i].title+'" type="checkbox" style="margin-right:5px"><span class="part">'+episodes[i].title+'</span></div><div class="duration bilidown" data-aid="'+episodes[i].aid+'" data-cid="'+episodes[i].cid+'" title="'+episodes[i].title+'">下载</div></div></a></li>';
                    }

                }
                return Bilihtml;
            }
            var AddBi= commonFunction.Commonsetinterval("#danmukuBox");
            AddBi.then(async function(node){
                await commonFunction.sleep(3000);
                let Bilihtml = await listHtml();
                if(!Bilihtml){commonFunction.Toast("获取下载列表失败,刷新重试");return;}
                let dataV = node.attributes[2]?.name??"data-v";
                let downhtml = '<div id ="downBox" class="multi-page report-wrap-module report-scroll-module" '+dataV+' style="margin:0 0 10px 0;border-radius: 6px;background: #F1F2F3;"><div class="head-con"><div class="head-left"><h3>下载列表</h3></div><div class="head-right"><span class="next-button" id="sanlian"><span class="txt" style="color: #00a1d6;">一键三连</span></span></div></div><div class="cur-list"><ul class="list-box">'+Bilihtml+'</ul></div><div style="display: flex;justify-content: space-between;height: 42px;line-height: 42px;margin: 0px 15px;font-size: 14px;font-weight: bold;border-top: 1px solid #dadada;"><div><span style="margin-right: 20px;" id="all">全选</span><span id="delall">重置</span></div><div><span style="margin-right: 20px;" id="aria2set">设置</span><a id="pldown"><span>批量下载</span></a></div></div></div>';
                node.insertAdjacentHTML('afterEnd', downhtml);
                ControllerBilibili.bilibilidown();
            });
        },
        bilibilidown:function(){
            var inu = document.querySelector("#downBox");
            var b=inu.getElementsByTagName('input');
            Controlleraria2.aria2set(b);
            document.querySelector("#sanlian") .addEventListener('click',function() {
                console.log("一键三连");
                document.querySelector(".like").click();
                document.querySelector(".coin").click();
            });

            document.querySelector("#pldown") .addEventListener('click',function() {
                let passwordCode = commonFunction.getItem("plcode");
                if (passwordCode !=""&&passwordCode !=null) {
                    let headers = {
                        "Content-Type": "text/html; charset=utf-8"
                    };
                    let request = commonFunction.request("GET","http://tool.zhihupe.com/bdwpcs.php?m=BILIBILI&author="+author+"&PWD="+passwordCode,headers,null);
                    request.then(function(resdata){
                        let json=JSON.parse(resdata.data);
                        if(json.error == 1){
                            let arr =[];
                            b.forEach(function(element) {
                                if(element.checked == true){
                                    let aid = element.getAttribute("data-aid");
                                    let cid = element.getAttribute("data-cid");
                                    let title = element.getAttribute("title");
                                    let json ={
                                        "aid": aid,
                                        "cid": cid,
                                        "title": title,
                                    };
                                    arr.push(json);
                                }
                            })
                            if(arr.length == 0){
                                commonFunction.Toast("请选择需要下载的视频",3000)
                            }else{
                                ControllerBilibili.bipldown(arr);
                            }
                        }else if(json.error == -2){
                            let msg =json.msg
                            commonFunction.Toast(msg);
                        }else {
                            commonFunction.Toast('服务器请求失败,请重试!');
                        }
                    })
                }else {
                    commonFunction.Toast('请在脚本设置里输入验证码!');
                }
            });
            let biliList = document.getElementsByClassName('bilidown');
            console.log(biliList);
            for (var i = 0; i < biliList.length; i++) {
                biliList[i].addEventListener('click',function() {
                    let aid = this.getAttribute("data-aid");
                    let cid = this.getAttribute("data-cid");
                    let title = this.getAttribute("title");
                    let headers = {
                        "Content-type": "application/json"
                    };
                    let request = commonFunction.request("GET","https://api.bilibili.com/x/player/playurl?avid="+aid+"&cid="+cid+"&qn=112",headers,null);
                    request.then(function(resdata){
                        let obj=JSON.parse(resdata.data);
                        if(obj.code == 0){
                            window.open(obj.data.durl[0].url,false);
                            console.log(obj)
                        }else{
                            commonFunction.Toast("获取下载链接失败");
                        }
                    })

                });
            }
        },
        //批量下载相关代码
        bipldown:function(a){
            let pldownarr=[];
            for (var i = 0; i < a.length; i++) {
                let title =i+1+"."+a[i].title+".flv";
                let headers = {
                    "Content-type": "application/json"
                };
                let request = commonFunction.request("GET","https://api.bilibili.com/x/player/playurl?avid="+a[i].aid+"&cid="+a[i].cid+"&qn=112",headers,null);
                request.then(function(resdata){
                    let obj=JSON.parse(resdata.data);
                    if(obj.code == 0){
                        let json ={
                            "url": obj.data.durl[0].url,
                            "title":title.replace(/\//g, '-'),
                        };
                        pldownarr.push(json);
                        if(pldownarr.length==a.length){
                            console.log(pldownarr);
                            Controlleraria2.plaria2(-1,pldownarr);
                        }
                    }else{
                        commonFunction.Toast("获取下载链接失败");
                    }
                })
            }
        },

    };
    //Bilibili下载结束
    //喜马拉雅下载开始
    var Controllerximalaya = {
        addximalaya:async function(){
            //    await commonFunction.sleep(3000);
            if(config.playhref.indexOf("www.ximalaya.com/album")!= -1){
                let albumId = commonFunction.geturlid(config.playhref);
                let headers = {
                    "Content-type": "application/json"
                };
                let request = commonFunction.request("GET","https://www.ximalaya.com/revision/album/v1/getTracksList?albumId="+albumId+"&pageNum=1",headers,null);
                request.then(function(resdata){
                    let obj=JSON.parse(resdata.data);
                    if(obj.ret == 200){
                        let trackTotalCount =obj.data.trackTotalCount;
                        if(trackTotalCount<=100){
                            var page = 1
                            }else{
                                page =Math.ceil(trackTotalCount/100)
                            }
                        let arr1 =[];
                        return new Promise(function(resolve, reject){
                            recurTest(0, page,albumId,arr1);
                            function recurTest(j,length,albumId,arr){
                                setTimeout(function(){
                                    if(++j <= length){
                                        let headers = {
                                            "Content-type": "application/json"
                                        };
                                        let request2 = commonFunction.request("GET","https://www.ximalaya.com/revision/album/v1/getTracksList?albumId="+albumId+"&pageSize=100&pageNum="+j+"&sort=0",headers,null);
                                        request2.then(function(resdata2){
                                            let obj=JSON.parse(resdata2.data);
                                            if(obj.ret == 200){
                                                let tracks =obj.data.tracks;
                                                arr1 = arr.concat(tracks)
                                                console.log(arr1)
                                                recurTest(j, length,albumId,arr1);
                                                if(j==length){
                                                    resolve(arr1)
                                                };
                                            }else{
                                                commonFunction.Toast("获取下载列表失败");
                                            }
                                        });
                                        console.log(j, length,albumId)
                                    }
                                }, Math.random() * 100);
                            }
                        }).then((listarr) => {
                            let downhtml=""

                            for (var i = 0; i < listarr.length; i++) {

                                downhtml += '<li class="_nO"><input data-trackId="'+listarr[i].trackId+'" title="'+listarr[i].title+'" type="checkbox" style="margin-right:5px;position: relative;top: 1px;"><div class="text _nO" style="max-width: 160px;"><span style="font-size: 12px;" class="title _nO">'+listarr[i].index+'.'+listarr[i].title+'</span></div><div class="right _nO" style="margin: 0 5px;width: 35px;"><a class="ximadown" data-trackId="'+listarr[i].trackId+'" title="'+listarr[i].title+'"  href="javascript:void(0)" ><span class="time _nO" style="font-size: 12px;">下载</span></a></div></li>';
                            }
                            var xm= commonFunction.Commonsetinterval(".xui-card");
                            xm.then(function(node){
                                let listHTML ='<div class="xui-card" id="ximadown" style="font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;"><div class="xui-card" style="margin-bottom: 15px;"><div style="margin: 0;" class="xui-card-head border"><span class="xui-card-head-title" style="display: block;"><i style="color: #666;" class="xuicon xuicon-quanjubofangqi-xiazai font-icon-18"></i></i>下载列表<div  class="xui-card-extra"><a rel="nofollow" style="font-weight: bold;" class="xui-card-extra-title Tj_" href="javascript:void(0)"><span  id="aria2set">设置</span></a></div></span></div><div style="margin: 0;max-height: 300px;overflow-y: scroll;" class="xui-card-body"><div class="sound-list  H_g"><ul id="downBox">'+downhtml+'</ul></div></div><div style="display: flex;justify-content: space-between;height: 42px;line-height: 42px;font-size: 14px;font-weight: bold;"><div><span style="margin-right: 20px;" id="all">全选</span><span id="delall">重置</span></div><div><a id="pldown"><span>批量下载</span></a></div></div></div></div>';
                                node.insertAdjacentHTML('afterEnd',listHTML)
                                //  zhihuselect[i].insertAdjacentHTML('afterEnd',selectHtml);
                                Controllerximalaya.ximalayadown();
                            });
                        })
                    }
                });
            }else{
                let list = document.getElementsByClassName('album-cover');
                if(list!=null){
                    for (var i in list) {
                        list[i].addEventListener('click',function() {
                            let url =this.getAttribute("href");
                            const a = document.createElement('a');
                            document.body.appendChild(a)
                            a.style.display = 'none'
                            a.href = url;
                            a.target="_blank"
                            a.click();
                            window.location.reload();
                        })
                    }
                }
            }
        },
        ximalayadown:function(){
            var inu = document.querySelector("#downBox");
            var b=inu.querySelectorAll('input');
            Controlleraria2.aria2set(b);
            document.querySelector("#pldown").addEventListener('click',function() {
                let passwordCode = commonFunction.getItem("plcode");
                if (passwordCode !=""&&passwordCode !=null) {
                    let headers = {
                        "Content-Type": "text/html; charset=utf-8"
                    };
                    let request = commonFunction.request("GET","http://tool.zhihupe.com/bdwpcs.php?m=BILIBILI&author="+author+"&PWD="+passwordCode,headers,null);
                    request.then(function(resdata){
                        var json=JSON.parse(resdata.data);
                        if(json.error == 1){
                            let arr =[];
                            b.forEach(function(element) {
                                if(element.checked == true){
                                    let trackId = element.getAttribute("data-trackId");
                                    let title = element.getAttribute("title");
                                    let json ={
                                        "trackId": trackId,
                                        "title": title,
                                    };
                                    arr.push(json);
                                }
                            })
                            if(arr.length == 0){
                                commonFunction.Toast("请选择需要下载的视频",3000)
                            }else{
                                console.log(arr)
                                Controllerximalaya.ximapldown(arr);
                            }
                        }else if(json.error == -2){
                            let msg =json.msg
                            commonFunction.Toast(msg);
                        }else {
                            commonFunction.Toast('服务器请求失败,请重试!');
                        }

                    });
                }else {
                    commonFunction.Toast('请在脚本设置里输入验证码!');
                }
            });
            let ximaList = document.getElementsByClassName('ximadown');
            console.log(ximaList);
            for (var i = 0; i < ximaList.length; i++) {
                ximaList[i].addEventListener('click',function() {
                    let trackId = this.getAttribute("data-trackId");
                    let title = this.getAttribute("title");
                    let headers = {
                        "Content-type": "application/json"
                    };
                    let request = commonFunction.request("GET",'https://mobile.ximalaya.com/mobile-playpage/track/v3/baseInfo/'+new Date().getTime()+'?device=web&trackId='+trackId,headers,null);
                    request.then(function(resdata){
                        let obj = JSON.parse(resdata.data);
                        console.log(obj)
                        if(obj.ret == 0){
                            let downUrl = obj.trackInfo.playUrlList[0].url;

                            let str1 = downUrl.replaceAll('-','+');

                            let str2 = str1.replaceAll('_','/');

                            let num = str2.length%4;

                            if(num){

                                str2 += '===='.substr(num);
                            }

                            let url = CryptoJS.AES.decrypt({

                                ciphertext: CryptoJS.enc.Base64.parse(str2)

                            }, CryptoJS.enc.Hex.parse("aaad3e4fd540b0f79dca95606e72bf93"), {

                                mode: CryptoJS.mode.ECB,

                                padding: CryptoJS.pad.Pkcs7

                            }).toString(CryptoJS.enc.Utf8);

                            console.log(url);

                            if(url){

                                GM_download(url,obj.trackInfo.title+'.mp3');

                            }else{
                                commonFunction.Toast('解密地址失败');
                            }
                        }else{
                            commonFunction.Toast("获取下载链接失败");
                        }

                    });
                });
            }
        },
        ximapldown:function(arr){
            let pldownarr =[]
            for (var i = 0; i < arr.length; i++) {
                let title =i+"."+arr[i].title+".mp3";;
                let headers = {
                    "Content-type": "application/json"
                };
                let request = commonFunction.request("GET",'https://mobile.ximalaya.com/mobile-playpage/track/v3/baseInfo/'+new Date().getTime()+'?device=web&trackId='+arr[i].trackId,headers,null);
                request.then(function(resdata){
                    let obj = JSON.parse(resdata.data);
                    console.log(obj)
                    if(obj.ret == 0){
                        let downUrl = obj.trackInfo.playUrlList[0].url;

                        let str1 = downUrl.replaceAll('-','+');

                        let str2 = str1.replaceAll('_','/');

                        let num = str2.length%4;

                        if(num){

                            str2 += '===='.substr(num);
                        }

                        let url = CryptoJS.AES.decrypt({

                            ciphertext: CryptoJS.enc.Base64.parse(str2)

                        }, CryptoJS.enc.Hex.parse("aaad3e4fd540b0f79dca95606e72bf93"), {

                            mode: CryptoJS.mode.ECB,

                            padding: CryptoJS.pad.Pkcs7

                        }).toString(CryptoJS.enc.Utf8);

                        console.log(url);
                        url
                        if(url){

                            //  addUri(decrypted,title)
                            let json ={
                                "url": url,
                                "title": title,
                            };
                            pldownarr.push(json)
                            if(pldownarr.length==arr.length){
                                console.log(pldownarr);
                                Controlleraria2.plaria2(-1,pldownarr);
                            }
                        }else{
                            commonFunction.Toast('解密地址失败');
                        }
                    }else{
                        commonFunction.Toast("获取下载链接失败");
                    }
                });
            }
        },
    }
    //喜马拉雅下载结束
    //-----------------------------------------------------------------------
    //教育盘论坛开始
    var Controllerforum = {
        jiaoyupan:function(){
            var jiaoyupannode= commonFunction.Commonsetinterval(".copy_pswd");
            jiaoyupannode.then(function(node){
                let v = node.getAttribute("onclick");
                let data = v.split(",");
                let aid = data[0].split("'")[1];
                let formhash = data[1].split("'")[1];
                let href = window.location.origin + "/plugin.php?id=threed_attach:downld&aid=" + aid + "&formhash=" + formhash;
                console.log(href)
                let btnhtml='<div style="position: fixed;bottom: 100px;right: 50px;z-index: 99999999;background: #54be99;padding: 10px 20px;font-size: 18px;font-weight: bold;border-radius: 8px;box-shadow: 0px 0px 8px 1px #919191;"><a href='+href+' style="color: #fff;">点击此处免费下载</a></div>';
                document.body.insertAdjacentHTML('afterEnd',btnhtml);
            });
        }
    }

    //教育盘论坛结束
    //------------------------------------------------------------------------
    //文库下载开始
    var Controllerdocs = {
        jsPDF: function(){
            if (unsafeWindow.jspdf) return unsafeWindow.jspdf;
            commonFunction.GMaddScript('https://cdn.staticfile.org/jspdf/2.5.1/jspdf.umd.min.js');
            return unsafeWindow.jspdf;
        },
        addStatus:function(){
            const statusOverlay = `<div class="s-top s-top-status"><div class="s-panel"><div class="s-progress-wrapper"><div class="s-progress"></div></div><div class="s-status" style=""><div class="s-text" style="">正在加载...</div><div class="s-progress-text">0%<div></div></div></div></div></div>`;
            const messageOverlay = `<div class="s-top s-top-message"><div class="s-message">testtest</div></div>`;
            document.body.insertAdjacentHTML('afterbegin', statusOverlay);
            document.body.insertAdjacentHTML('afterbegin', messageOverlay);
            document.head.appendChild(document.createElement('style')).innerHTML = `
            .s-top {
              position: fixed;
              top: 0;
              left: 0;
              bottom: 0;
              right: 0;
              z-index: 99999999;
              padding-top: 40vh;
              display: none;
            }

            .s-top.s-top-message {
              text-align: center;
            }

            .s-message {
              background-color: #000000aa;
              color: white;
              padding: 8px 14px;
              text-align: center;
              font-size: 18px;
              border-radius: 6px;
              display: inline-block;
            }

            .s-top.s-top-status {
              z-index: 99999998;
              cursor: wait;
              background-color: rgba(0, 0, 0, 0.4);
              backdrop-filter: blur(10px) saturate(1.8);
            }

            .s-top.show {
              display: block;
            }

            .s-panel {
              background: white;
              width: 90%;
              max-width: 480px;
              border-radius: 12px;
              padding: 14px 24px;
              margin: 0 auto;
            }

            .s-progress-wrapper {
              height: 24px;
              border-radius: 12px;
              width: 100%;
              background-color: #eeeff3;
              overflow: hidden;
              margin-bottom: 12px;
            }

            .s-progress {
              background-color: #54be99;
              height: 24px;
              width: 0;
              transition: width 0.2s ease;
            }

            .s-status {
              display: flex;
              font-size: 14px;
            }

            .s-text {
              flex-grow: 1;
              color: #5f5f5f;
            }

            .s-progress-text {
              color: #54be99;
              font-weight: bold;
            }

            .s-message {

            }
            .swal2-actions {
               margin: 20px auto 0;
            }
            .swal2-styled.swal2-cancel{
               border-radius: 5px;
               font-size: 16px;
            }
            .swal2-styled.swal2-confirm{
               border-radius: 5px;
               font-size: 16px;
            }
            .swal2-styled {
                margin: 5px;
                padding: 8px 16px;
            }
            .none{
                display:none
            }
          `;
        },
        showStatus:function(text='', progress=-1){
            document.querySelector('.s-top.s-top-status').classList.add('show');
            if(text) document.querySelector('.s-panel .s-text').innerHTML = text;
            if (progress >= 0) {
                progress = Math.min(progress, 100);
                document.querySelector('.s-panel .s-progress').style.width = `${Math.floor(progress)}%`;
                document.querySelector('.s-panel .s-progress-text').innerHTML = `${Math.floor(progress)}%`;
            }
        },
        hideStatus:function(){
            document.querySelector('.s-top.s-top-status').classList.remove('show');
        },
        imgtocanvas:async function (doc,pageSize,img){
            const canvas = document.createElement('canvas');
            const [w, h] = [canvas.width, canvas.height] = [pageSize[0],pageSize[1]];
            const ctx = canvas.getContext('2d');
            ctx.drawImage(img, 0,0);
            doc.addImage(canvas, 'PNG',0, 0, w, h);
            canvas.remove();
        },
        yuanchuangliPPT:async function(){
            await Controllerdocs.addStatus();
            const loadScript = url => new Promise((resolve, reject) => {
                const removeWrap = (func, ...args) => {
                    if (script.parentNode) script.parentNode.removeChild(script);
                    return func(...args)
                }
                const script = document.createElement('script');
                script.src = url;
                script.onload = removeWrap.bind(null, resolve);
                script.onerror = removeWrap.bind(null, reject);
                document.head.appendChild(script);
            })
            const loadJsPDF = async () => {
                if (unsafeWindow.jspdf) return unsafeWindow.jspdf;
                await loadScript('https://cdn.staticfile.org/jspdf/2.5.1/jspdf.umd.min.js');
                return unsafeWindow.jspdf;
            }
            const htmltocanvas = (view,w,h)=>new Promise(async (resolve, reject) => {
                html2canvas(view).then((canvas)=> {
                    resolve(canvas);
                    console.log(canvas)
                });
            })
            const downloadPDF = async ()=>{
                const jspdf = await loadJsPDF();
                await commonFunction.GMaddScript("https://cdn.staticfile.org/html2canvas/1.4.1/html2canvas.min.js");
                let PageCount = Page_Count();
                let doc;
                let docview = document.querySelector(`#view0`);
                var w = parseInt(docview.clientWidth);
                var h = parseInt(docview.clientHeight);
                var pageSize =[w,h]
                Controllerdocs.showStatus('正在加载', 0);
                for(let i = 0;i<PageCount; i++){
                    await unsafeWindow.gosld(i);
                    Controllerdocs.showStatus('正在准备', ((i + 1) /PageCount) * 100);
                    await commonFunction.sleep(100);
                    let doc_view = document.querySelector(`#view${i}`);
                    console.log(doc_view);
                    Controllerdocs.showStatus('正在合成图片');
                    let canvas = await htmltocanvas(doc_view,w,h) ;
                    console.log(canvas);
                    if (!doc) {
                        doc = new jspdf.jsPDF(pageSize[0] < pageSize[1] ? 'p' : 'l', 'pt', pageSize);
                    } else {
                        doc.addPage(pageSize);
                    }
                    var pageData = canvas.toDataURL('image/jpeg', 1.0);
                    console.log(pageData)
                    doc.addImage(pageData, 'JPEG', 0, 0, w, h);
                }
                doc.save(`原创力ppt.pdf`);
                Controllerdocs.hideStatus();
            }
            const current_page = ()=>{
                let currentpage = document.querySelector("#PageIndex").innerText;
                currentpage = parseInt(currentpage);
                return currentpage;
            }
            const Page_Count = ()=>{
                let PageCount = document.querySelector("#PageCount").innerText;
                PageCount = parseInt(PageCount);
                return PageCount;
            }
            const pagenum = ()=>{
                let currentpage = current_page();
                let PageCount = Page_Count();
                if(currentpage<PageCount){
                    let page = PageCount - currentpage;
                    previewNextpage(page,false);
                }else{
                    previewNextpage(10,true);
                }

            }
            const previewNextpage = async (page,type)=>{
                for(let i = 0;i<page; i++){
                    commonFunction.Toast("正在预览全文,请勿操作",600);
                    document.querySelector(".btmRight").click();
                    await commonFunction.sleep(500);
                }
                if(type == false){
                    pagenum();
                }else{
                    await unsafeWindow.gosld(0);
                    await commonFunction.sleep(1000);
                    downloadPDF();
                }

            }
            const btnhtml =`<div id="ycbox" style="box-shadow: 0 0 6px 3px #00000038;z-index: 99999997;top: 100px;position: fixed;right: 50px;background: #fff;padding: 0 20px;border-radius: 5px;"><div id="jxdown" style=" text-align: center;font-size: 14px;padding: 8px 15px;background: #54be99;color: #fff;margin: 10px 0;border-radius: 3px;">开始下载</div></div>`;
            document.body.insertAdjacentHTML('afterbegin', btnhtml);
            document.querySelector("#jxdown").onclick = ()=>{
                pagenum();

            }
        },
        yuanchuangli:async function(){
            await Controllerdocs.addStatus();
            const imgLoad = (url) => {
                var img = new Image();
                img.src = url;
                if (img.complete) {
                    return [img.width, img.height];
                } else {
                    img.onload = function () {
                        return [img.width, img.height];
                        img.onload = null;
                    };
                };
            };
            const loadImage = (url) => new Promise(async (resolve, reject) => {
                if (!url) {
                    resolve(null);
                    return;
                }
                let img = await request('GET', url, null, 'blob');
                let imgEl = document.createElement('img');
                imgEl.onload = () => {
                    resolve(imgEl);
                }
                imgEl.onabort = imgEl.onerror = reject;
                imgEl.src = URL.createObjectURL(img);
            })
            const request = (method, url, data, responseType = 'text') => new Promise((resolve, reject) => {
                GM.xmlHttpRequest({
                    method,
                    url,
                    data,
                    responseType,
                    onerror: reject,
                    ontimeout: reject,
                    onload: (response) => {
                        if (response.status >= 200 && response.status < 300) {
                            resolve(responseType === 'text' ? response.responseText : response.response);
                        } else {
                            reject(new Error(response.statusText));
                        }
                    }
                });
            });
            const loadScript = url => new Promise((resolve, reject) => {
                const removeWrap = (func, ...args) => {
                    if (script.parentNode) script.parentNode.removeChild(script);
                    return func(...args)
                }
                const script = document.createElement('script');
                script.src = url;
                script.onload = removeWrap.bind(null, resolve);
                script.onerror = removeWrap.bind(null, reject);
                document.head.appendChild(script);
            })

            const loadJsPDF = async () => {
                if (unsafeWindow.jspdf) return unsafeWindow.jspdf;
                await loadScript('https://cdn.staticfile.org/jspdf/2.5.1/jspdf.umd.min.js');
                return unsafeWindow.jspdf;
            }
            const downloadPDF = async (WebPreview)=>{
                let titleText = unsafeWindow?.base.detail.title;
                let title;
                if(titleText){
                    title = titleText.split(".")[0]
                }else{
                    title = "原创力文档"
                }
                Controllerdocs.showStatus('正在加载', 0);
                const jspdf = await loadJsPDF();
                let doc;
                let previewImages = WebPreview.Data.images;
                const img = imgLoad(previewImages[1].src);
                let startnum = unsafeWindow.fenpi.startnum;
                let endnum = unsafeWindow.fenpi.endnum;
                for(let i = startnum;i <= endnum; i++){
                    Controllerdocs.showStatus('正在准备', ((i + 1) / previewImages.length) * 100);
                    const pageSize =[img[0],img[1]];
                    console.log(img[1])
                    if (!doc) {
                        doc = new jspdf.jsPDF(pageSize[0] < pageSize[1] ? 'p' : 'l', 'pt', pageSize);
                    } else {
                        doc.addPage(pageSize);
                    }
                    Controllerdocs.showStatus('正在下载图片');
                    const previewImg = await loadImage(previewImages[i].src);
                    await Controllerdocs.imgtocanvas(doc,pageSize,previewImg);
                    Controllerdocs.showStatus('正在绘制');
                    if(previewImg?.src) URL.revokeObjectURL(previewImg.src);
                    previewImg.remove();

                }
                doc.save(`${title}.pdf`);
                Controllerdocs.hideStatus();
            }
            const checkPreview = (WebPreview) =>{
                let previewImages = WebPreview.Data.images;
                let arr =[];
                for(let i = 1;i < previewImages.length; i++){
                    if(previewImages[i].status == "init") arr.push(i);
                }
                return arr;

            }
            const Previewresult = (WebPreview)=>{
                let Previewfalse = checkPreview(WebPreview);
                var toasttext = "";
                if(Previewfalse != ""){
                    for ( let key in Previewfalse){
                        toasttext += "第"+Previewfalse[key]+"页;";
                        document.querySelector("#jxdown").style.display = "block";
                        document.querySelector("#downbox").style.display = "none";
                    }
                    commonFunction.Toast(toasttext+"预览失败,请手动预览上述页码",5000);
                }else{
                    downloadPDF(WebPreview);
                }
            }
            const exportPDF = async(event,startnum,endnum,yulannum)=>{
                let WebPreview = unsafeWindow?.WebPreview;
                let previewmain =document.querySelector('.preview');
                if(yulannum == "") yulannum = 100;
                unsafeWindow.fenpi ={
                    startnum:1,
                    endnum:WebPreview.Data.preview_page

                }
                try {
                    if(!WebPreview){
                        commonFunction.Toast("文档下载失败,刷新页面重试一次",3000);
                        return
                    }
                    if(previewmain){
                        previewmain.style.display = "block"
                    }else{
                        commonFunction.Toast("预览失败",3000);
                        return
                    }
                    if(startnum!=""&&endnum!=""){
                        if(parseInt(startnum)<parseInt(endnum)){
                            if(parseInt(endnum)>WebPreview.Data.preview_page||parseInt(startnum)<1){
                                commonFunction.Toast('页码输入错误,结束页码大于可预览页数或者起始页码小于1');
                                return
                            }else{
                                unsafeWindow.fenpi.startnum = startnum;
                                unsafeWindow.fenpi.endnum = endnum;
                                console.log(unsafeWindow.fenpi.startnum)
                            }
                        }else{
                            commonFunction.Toast('页码输入错误,结束页码小于或等于开始页码');
                            return
                        }
                    }
                    await unsafeWindow.preview.jump(999);
                    await commonFunction.sleep(1500);
                    event.preventDefault();
                    var currentLocation = document.documentElement.scrollTop;// 获取当前滚动条的位置
                    var task = setInterval(function (){ // setInterval循环周期调用
                        if (currentLocation>0){
                            window.scrollTo(0,currentLocation);
                            currentLocation -=yulannum // 相比上次位置减10,根据自己需要的速度修改
                            commonFunction.Toast("正在预览全文,请勿操作",200);
                        }else {
                            window.scrollTo(0,0);
                            Previewresult(WebPreview);
                            clearInterval(task) //回到顶部后,清除已执行的的循环事件
                        }
                    },200)

                    } catch (error) {
                        commonFunction.Toast('导出失败:'+error?.message ?? error);
                    } finally {
                        Controllerdocs.hideStatus();
                    }

            }
            const exportPPT = async()=>{
                try {
                    unsafeWindow.preview.getSrc();
                    var xm= commonFunction.Commonsetinterval("iframe.preview-iframe");
                    xm.then(function(node){
                        window.open(node.src);
                        unsafeWindow.preview.close();
                    });

                } catch (error) {
                    commonFunction.Toast('导出失败:'+error?.message ?? error);
                } finally {
                    Controllerdocs.hideStatus();
                }

            }
            const btnhtml =`<div id="ycbox" style="box-shadow: 0 0 6px 3px #00000038;z-index: 99999997;top: 100px;position: fixed;right: 50px;background: #fff;padding: 0 20px;border-radius: 5px;"><div id="downbox"><div><p style="font-size: 14px;margin: 10px 0;">分批下载</p><div><input id="start" style="width: 35px;padding: 2px;"> <span style="margin: 0 5px;">-</span><input id="end" style="width: 35px;padding: 2px;"></div></div><div><p style="font-size: 14px;margin: 10px 0;">预览速度</p><div><input id="yulan" type= number placeholder="200" style="width: 60px;padding: 2px;"> <span style="margin: 0 5px;">像素</span></div></div><div id="ycdown" style="text-align: center;font-size: 14px;padding: 8px 15px;background: #54be99;color: #fff;margin: 10px 0;border-radius: 3px;">下载文档</div></div><div id="jxdown" style=" display:none; text-align: center;font-size: 14px;padding: 6px 13px;background: #fff;color: #54be99;margin: 10px 0;border-radius: 3px;border: 1px solid #54be99;">继续下载</div></div>`;
            document.body.insertAdjacentHTML('afterbegin', btnhtml);
            document.querySelector("#ycdown").onclick = (event)=>{
                let base = unsafeWindow?.base;
                console.log(base.detail.format);
                let startnum = document.querySelector('#start').value;
                let endnum = document.querySelector("#end").value;
                let yulannum = document.querySelector("#yulan").value;
                if(!base.detail.format){
                    commonFunction.Toast("文档信息获取失败,刷新页面重试一次",3000);
                    return
                }else if(base.detail.format == "ppt"||base.detail.format == "pptx"){
                    if(startnum||endnum){
                        commonFunction.Toast("PPT不支持分批下载",3000);
                    }else{
                        exportPPT();
                    }
                }else{
                    exportPDF(event,startnum,endnum,yulannum);
                }
            }
            document.querySelector("#jxdown").onclick = ()=>{
                let WebPreview = unsafeWindow?.WebPreview;
                Previewresult(WebPreview);
            }
        },
        daokebaba:async function(){
            await Controllerdocs.addStatus();
            const loadScript = url => new Promise((resolve, reject) => {
                const removeWrap = (func, ...args) => {
                    if (script.parentNode) script.parentNode.removeChild(script);
                    return func(...args)
                }
                const script = document.createElement('script');
                script.src = url;
                script.onload = removeWrap.bind(null, resolve);
                script.onerror = removeWrap.bind(null, reject);
                document.head.appendChild(script);
            })

            const loadJsPDF = async () => {
                if (unsafeWindow.jspdf) return unsafeWindow.jspdf;
                await loadScript('https://cdn.staticfile.org/jspdf/2.5.1/jspdf.umd.min.js');
                return unsafeWindow.jspdf;
            }
            const Previewresult = ()=>{
                let Previewfalse = document.getElementsByClassName("page_pb");
                console.log(Previewfalse)
                var toasttext = "";
                for ( let i=0; i < Previewfalse.length;i++){
                    if(Previewfalse[i].innerHTML != ""){
                        let falseid= Previewfalse[i].getAttribute("id");
                        let falsenum =falseid.split("_");
                        toasttext += "第"+falsenum[1]+"页;";
                        document.querySelector("#jxdown").style.display = "block";
                        document.querySelector("#downbox").style.display = "none";
                    }
                }
                if(toasttext != ""){
                    commonFunction.Toast(toasttext+"预览失败,请手动预览上述页码",5000);
                }else{
                    downloadPDF();
                }
            }
            const downloadPDF = async ()=>{
                let title = document.querySelector('.doctopic h1').innerText;
                if( !title) title = "道客巴巴文档"
                const jspdf = await loadJsPDF();
                let doc;
                let canvas = unsafeWindow.daoke.canvas;
                var w = parseInt(canvas[0].clientWidth);
                var h = parseInt(canvas[0].clientHeight);
                var pageSize =[w,h]
                Controllerdocs.showStatus('正在加载', 0);
                let startnum = unsafeWindow.daoke.startnum - 1;
                let endnum = unsafeWindow.daoke.endnum;
                for(let i = startnum;i<endnum; i++){
                    Controllerdocs.showStatus('正在准备', ((i + 1) /canvas.length) * 100);
                    if (!doc) {
                        doc = new jspdf.jsPDF(pageSize[0] < pageSize[1] ? 'p' : 'l', 'pt', pageSize);
                    } else {
                        doc.addPage(pageSize);
                    }
                    Controllerdocs.showStatus('正在合成图片');
                    var pageData = canvas[i].toDataURL('image/jpeg', 1.0);
                    console.log(canvas[i])
                    doc.addImage(pageData, 'JPEG', 0, 0, w, h);
                    await commonFunction.sleep(100);
                }
                doc.save(`${title}.pdf`);
                Controllerdocs.hideStatus();
            }
            const exportPDF = async(event,startnum,endnum,yulannum)=>{
                await unsafeWindow.buyContinueRead();
                unsafeWindow.daoke ={
                    canvas:[],
                    startnum:1,
                    endnum:"",
                }
                if(yulannum == "") yulannum = 600;
                let bodyheight =document.body.scrollHeight;
                await window.scrollTo(0,bodyheight);
                let canvas = unsafeWindow.daoke.canvas = document.getElementsByClassName("inner_page");
                if(!canvas) {commonFunction.Toast("文档信息获取失败,刷新页面重试一次",3000);return;}
                unsafeWindow.daoke.endnum = canvas.length;
                console.log(unsafeWindow.daoke.endnum);
                try {
                    if(startnum!=""&&endnum!=""){
                        if(parseInt(startnum)<parseInt(endnum)){
                            if(parseInt(endnum)>canvas.length||parseInt(startnum)<1){
                                commonFunction.Toast('页码输入错误,结束页码大于可预览页数或者起始页码小于1');
                                return
                            }else{
                                unsafeWindow.daoke.startnum = startnum;
                                unsafeWindow.daoke.endnum = endnum;

                            }
                        }else{
                            commonFunction.Toast('页码输入错误,结束页码小于或等于开始页码');
                            return
                        }
                    }
                    event.preventDefault();
                    var currentLocation = document.documentElement.scrollTop;// 获取当前滚动条的位置
                    var task = setInterval(function (){ // setInterval循环周期调用
                        if (currentLocation>0){
                            window.scrollTo(0,currentLocation);
                            currentLocation -=yulannum // 相比上次位置减10,根据自己需要的速度修改
                            commonFunction.Toast("正在预览全文,请勿操作",1000);
                        }else {
                            window.scrollTo(0,0);
                            Previewresult();
                            clearInterval(task) //回到顶部后,清除已执行的的循环事件
                        }
                    },1000)

                    } catch (error) {
                        commonFunction.Toast('导出失败:'+error?.message ?? error);
                    } finally {
                        Controllerdocs.hideStatus();
                    }

            }
            const btnhtml =`<div id="dkbox" style="box-shadow: 0 0 6px 3px #00000038;z-index: 99999997;top: 100px;position: fixed;right: 50px;background: #fff;padding: 0 20px;border-radius: 5px;"><div id="downbox"><div><p style="font-size: 14px;margin: 10px 0;">分批下载</p><div><input type= number id="start" style="width: 35px;padding: 2px;"> <span style="margin: 0 5px;">-</span><input type= number id="end" style="width: 35px;padding: 2px;"></div></div><div><p style="font-size: 14px;margin: 10px 0;">预览速度</p><div><input id="yulan" type= number placeholder="600" style="width: 60px;padding: 2px;"> <span style="margin: 0 5px;">像素</span></div></div><div id="dkdown" style="text-align: center;font-size: 14px;padding: 8px 15px;background: #54be99;color: #fff;margin: 10px 0;border-radius: 3px;">下载文档</div></div><div id="jxdown" style=" display:none; text-align: center;font-size: 14px;padding: 6px 13px;background: #fff;color: #54be99;margin: 10px 0;border-radius: 3px;border: 1px solid #54be99;">继续下载</div></div>`;
            document.body.insertAdjacentHTML('afterbegin', btnhtml);
            document.querySelector("#dkdown").onclick = (event)=>{
                let startnum = document.querySelector('#start').value;
                let endnum = document.querySelector("#end").value;
                let yulannum = document.querySelector("#yulan").value;
                exportPDF(event,startnum,endnum,yulannum);

            }
            document.querySelector("#jxdown").onclick = ()=>{
                Previewresult();
            }
        },

        zhiku:async function(){
            await Controllerdocs.addStatus();
            const loadScript = url => new Promise((resolve, reject) => {
                const removeWrap = (func, ...args) => {
                    if (script.parentNode) script.parentNode.removeChild(script);
                    return func(...args)
                }
                const script = document.createElement('script');
                script.src = url;
                script.onload = removeWrap.bind(null, resolve);
                script.onerror = removeWrap.bind(null, reject);
                document.head.appendChild(script);
            })
            const loadJsPDF = async () => {
                if (unsafeWindow.jspdf) return unsafeWindow.jspdf;
                await loadScript('https://cdn.staticfile.org/jspdf/2.5.1/jspdf.umd.min.js');
                return unsafeWindow.jspdf;
            }
            const setIntervalPage = data => new Promise((resolve, reject) => {
                let num = 0;
                let Count = setInterval(function() {
                    var node = document.querySelector(data);
                    num++;
                    if(node != null ){
                        clearInterval(Count);
                        commonFunction.Toast("正在预览全文,请勿操作",unsafeWindow.zhiku.yulannum);
                        setTimeout(() => {
                            let pageData = node.toDataURL('image/jpeg', 1.0);
                            let canvas ={
                                "src":pageData,
                                "width":node.width,
                                "height":node.height,
                            }
                            unsafeWindow.zhiku.canvas.push(canvas);
                            resolve(node);
                        },unsafeWindow.zhiku.yulannum);
                    }
                    console.log(num)
                    if(num ==50){
                        return false;
                        clearInterval(Count);
                    }
                    console.log(node)
                },200);

            })
            const Preview = async (page)=>{
                for (let i = unsafeWindow.zhiku.startnum;i <=unsafeWindow.zhiku.endnum;i++){
                    document.querySelector('#pageContainer'+i).scrollIntoView({behavior: "smooth"});
                    let zk = await setIntervalPage("#page"+i);
                    if(zk == false) return false;
                }
                return true;
            }
            const downloadPDF = async ()=>{
                const jspdf = await loadJsPDF();
                let doc;
                let canvas = unsafeWindow.zhiku.canvas;
                console.log(canvas);
                Controllerdocs.showStatus('正在加载', 0);
                let startnum = unsafeWindow.zhiku.startnum - 1;
                let endnum = unsafeWindow.zhiku.endnum;
                for(let i = 0;i<canvas.length; i++){
                    var w = canvas[i].width;
                    var h = canvas[i].height;
                    var pageSize =[w,h]
                    Controllerdocs.showStatus('正在准备', ((i + 1) /canvas.length) * 100);
                    if (!doc) {
                        doc = new jspdf.jsPDF(pageSize[0] < pageSize[1] ? 'p' : 'l', 'pt', pageSize);
                    } else {
                        doc.addPage(pageSize);
                    }
                    Controllerdocs.showStatus('正在合成图片');
                    doc.addImage(canvas[i].src, 'JPEG', 0, 0, w, h);
                    await commonFunction.sleep(100);
                }
                doc.save(`${unsafeWindow?.wgDocTitle ?? '智库文库文档'}.pdf`);
                Controllerdocs.hideStatus();
            }
            const exportPDF = async (startnum,endnum,yulannum)=>{
                let page = document.querySelectorAll('.page');
                if(!page){
                    commonFunction.Toast("文档下载失败,刷新页面重试一次",3000);
                    return
                }
                if(yulannum == "") yulannum = 1500;
                unsafeWindow.zhiku ={
                    "startnum":1,
                    "endnum":page.length,
                    "yulannum":yulannum,
                    "canvas":[]
                }
                try {
                    if(startnum!=""&&endnum!=""){
                        if(parseInt(startnum)<parseInt(endnum)){
                            if(parseInt(endnum)>page.length||parseInt(startnum)<1){
                                commonFunction.Toast('页码输入错误,结束页码大于可预览页数或者起始页码小于1');
                                return
                            }else{
                                unsafeWindow.zhiku.startnum = startnum;
                                unsafeWindow.zhiku.endnum = endnum;
                            }
                        }else{
                            commonFunction.Toast('页码输入错误,结束页码小于或等于开始页码');
                            return
                        }
                    }
                    document.querySelector('#pageContainer'+unsafeWindow.zhiku.startnum).scrollIntoView({behavior: "smooth"});
                    await commonFunction.sleep(1000)
                    let Previewresult = await Preview(page);
                    if(Previewresult) downloadPDF();
                } catch (error) {
                    commonFunction.Toast('导出失败:'+error?.message ?? error);
                } finally {
                    Controllerdocs.hideStatus();
                }

            }
            const btnhtml =`<div id="dkbox" style="box-shadow: 0 0 6px 3px #00000038;z-index: 99999997;top: 100px;position: fixed;right: 50px;background: #fff;padding: 0 20px;border-radius: 5px;"><div id="downbox"><div><p style="font-size: 14px;margin: 10px 0;">分批下载</p><div><input type= number id="start" style="width: 35px;padding: 2px;border: 1px solid #333;border-radius: 2px;"> <span style="margin: 0 5px;">-</span><input type= number id="end" style="width: 35px;padding: 2px;border: 1px solid #333;border-radius: 2px;"></div></div><div><p style="font-size: 14px;margin: 10px 0;">预览速度</p><div><input id="yulan" type= number placeholder="1500" style="width: 60px;padding: 2px;border: 1px solid #333;border-radius: 2px;"> <span style="margin: 0 5px;font-size:12px">毫秒</span></div></div><div id="dkdown" style="text-align: center;font-size: 14px;padding: 8px 15px;background: #54be99;color: #fff;margin: 10px 0;border-radius: 3px;">下载文档</div></div></div></div>`;
            document.body.insertAdjacentHTML('afterbegin', btnhtml);
            document.querySelector("#dkdown").onclick = (event)=>{
                let startnum = document.querySelector('#start').value;
                let endnum = document.querySelector("#end").value;
                let yulannum = document.querySelector("#yulan").value;
                exportPDF(startnum,endnum,yulannum);

            }
        },

    };
    var Controllercsdn = {
        blog:async function(){
            const copy =()=>{
                let copynode = document.querySelectorAll("pre");
                copynode.forEach(function(item){
                    item.style.cssText = "user-select: auto;";
                    item.querySelector("code").style.cssText = "user-select: auto;";
                    item.querySelector("code").setAttribute("onclick","mdcp.copyCode(event)");
                    item.querySelector(".hljs-button").setAttribute("class","hljs-button {2}");
                    item.querySelector(".hljs-button").setAttribute("data-title","复制");
                });
                let copybtn = document.querySelectorAll("code .hljs-button");
                copybtn.forEach(function(item){
                    item.addEventListener('click',function() {
                        setTimeout(function(){
                            item.setAttribute("data-title","复制");
                            console.log("复制")
                        },3500);
                    });
                });
                commonFunction.Toast("解除复制限制成功",500);

            };
            const quanwen =() =>{
                var hide = commonFunction.Commonsetinterval(".hide-article-box.text-center");
                hide.then(function(hidenode){
                    hidenode.parentNode.removeChild(hidenode);
                    document.getElementById("article_content").style="height: *px; ";
                    commonFunction.Toast("解除阅读全文限制成功",500);
                });
            }
            const link =()=>{
                let linknode = document.getElementById("article_content").querySelectorAll("a");
                linknode.forEach(function(item){
                    if(item.origin!= window.location.origin){
                        item.onclick =(event)=> {
                            if (event.stopPropagation) {
                                event.stopPropagation();
                            }
                            item.setAttribute("target", "_blank");
                        };
                        commonFunction.Toast("解除外链重定向限制成功",500);
                    }
                })
            }
            //去除复制小尾巴
            try {
                // 复制时保留原文格式,参考 https://greasyfork.org/en/scripts/390502-csdnremovecopyright/code
                Object.defineProperty(unsafeWindow, "articleType", {
                    value: 0,
                    writable: false,
                    configurable: false
                });
            } catch (error) {
                console.log(error)
            }
            await commonFunction.sleep(1500);
            await copy();
            await quanwen();
            await link();
        }
    };
    //-------------------------------------
    //脚本设置开始
    if(commonFunction.IsPC()===true){
        commonFunction.menusetting();
        // GM_deleteValue("videosetting");
        var Menu=GM_registerMenuCommand ("脚本设置", function(){
            var menulist = [
                {name:"VIP视频解析功能",value:"videosetting",set:commonFunction.GMgetValue("videosetting"),},
                {name:"电商优惠券查询功能",value:"couponsetting",set:commonFunction.GMgetValue("couponsetting"),},
                {name:"电商历史价格查询功能",value:"historysetting",set:commonFunction.GMgetValue("historysetting"),},
                {name:"短视频无水印下载功能",value:"Shortvideosetting",set:commonFunction.GMgetValue("Shortvideosetting"),},
                {name:"Bilibili无水印下载功能",value:"Bilibilisetting",set:commonFunction.GMgetValue("Bilibilisetting"),},
                {name:"喜马拉雅下载功能",value:"Ximalayasetting",set:commonFunction.GMgetValue("Ximalayasetting"),},
                {name:"教育盘论坛下载功能",value:"Jiaoyupansetting",set:commonFunction.GMgetValue("Jiaoyupansetting"),},
                {name:"文档下载功能",value:"Docssetting",set:commonFunction.GMgetValue("Docssetting"),},
                {name:"CSDN优化功能",value:"Csdnsetting",set:commonFunction.GMgetValue("Csdnsetting"),},

            ]
            var mainHTML = ""
            for(i in menulist){
                let text = menulist[i].set===1?"关闭":"开启";
                let style =menulist[i].set===1?"border: 1px solid #cacaca;":"border: 1px solid #54be99;color: #54be99;";
                mainHTML += '<div style="display: flex;justify-content: space-between;font-size: 14px;height: 38px;line-height: 38px;"><div>'+menulist[i].name+'</div><button style="font-size: 14px;padding: 0px 10px;line-height: 18px;height: 28px;'+style+'border-radius: 5px;margin: 5px 0;background: #fff0;"  class="s" data-name="'+menulist[i].name+'" data-value="'+menulist[i].value+'">'+text+'</button></div>'
            }

            let m = document.createElement('div');
            m.innerHTML = '<h2 style="font-size: 18px;font-weight: bold;margin: 0 0 10px 0;line-height: 40px;">脚本功能设置</h2>'+mainHTML+'<button style="font-size: 14px;padding: 0 10px;line-height: 28px;height: 38px;border: 0;border-radius: 5px;margin: 10px 0;background: #54be99;color: #fff;width: 80px;" id="CloseMenu">关闭</button>';
            console.log(m)
            m.setAttribute('id','Menu');
            m.style.cssText = "box-shadow: 0px 0px 8px 1px rgb(98 99 99 / 34%);max-width:60%;width: 280px;padding:10px 20px;min-height: 40px;line-height: 40px;text-align: center;border-radius: 10px;position: fixed;top: 50%;left: 50%;transform: translate(-50%, -50%);z-index: 99999999;background: #fff;font-size: 16px;font-family: PingFang SC, HarmonyOS_Regular, Helvetica Neue, Microsoft YaHei, sans-serif;";
            document.body.appendChild(m);
            let s = document.getElementsByClassName("s");
            for (var i = 0; i < s.length; i++) {
                s[i].addEventListener('click',function() {
                    var name = this.getAttribute("data-value");
                    if(commonFunction.GMgetValue(name)=== 1){
                        commonFunction.GMsetValue(name,0);
                        this.innerText = "开启";
                        commonFunction.Toast(this.getAttribute("data-name")+"已关闭",1500);
                    }else{
                        commonFunction.GMsetValue(name,1);
                        this.innerText = "关闭";
                        commonFunction.Toast(this.getAttribute("data-name")+"已开启",1500);
                    }
                });
            }
            document.querySelector("#CloseMenu").addEventListener('click',function() {
                document.body.removeChild(document.querySelector("#Menu"));
                window.location.reload();
            })

        }, "h");
    }
    //脚本设置结束
    //-------------------------------------------------------------------------
    //统一判断运行
    if(commonFunction.GMgetValue("isuser") == 1){
        switch (config.host) {
            case 'v.qq.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                    console.log('已进入腾讯');
                    var mask = commonFunction.Commonsetinterval("#mask_layer");
                    mask.then(function(masknode){
                        masknode.parentNode.removeChild(masknode);
                    });
                    var mod = commonFunction.Commonsetinterval(".mod_vip_popup");
                    mod.then(function(modnode){
                        modnode.parentNode.removeChild(modnode);
                    });
                    var panel = commonFunction.Commonsetinterval(".panel-tip-pay");
                    panel.then(function(panelnode){
                        panelnode.parentNode.removeChild(panelnode);
                    });
                }
                break;
            case 'v.youku.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    console.log('已进入优酷')
                }
                break;
            case 'www.iqiyi.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                    console.log('已进入爱奇艺')
                }
                break;
            case 'www.mgtv.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                    console.log('已进入芒果TV')
                }
                break;
            case 'w.mgtv.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                    console.log('已进入芒果TV')
                }
                break;
            case 'www.bilibili.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    if (config.playhref.indexOf("www.bilibili.com/bangumi/play") != -1) {
                        ControllerVideo.addbtn();
                        commonFunction.setIntervalhost();
                    }
                }
                if(commonFunction.GMgetValue("Bilibilisetting")===1){
                    ControllerBilibili.Addlist();
                   
                }
                console.log('已进入bilibili')
                break;
            case 'www.le.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                }
                console.log('已进入乐视TV')
                break;
            case 'film.sohu.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                }
                console.log('已进入搜狐会员')
                break;
            case 'tv.sohu.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                    commonFunction.setIntervalhost();
                }
                console.log('已进入搜狐')
                break;
            case 'www.wasu.cn':
                if(commonFunction.GMgetValue("videosetting")===1){
                    if(config.playhref.indexOf("www.wasu.cn/Play/")!=-1){
                        ControllerVideo.addbtn();
                    }else{
                        ControllerVideo.addmobbtn();
                    }
                }
                console.log('已进入华数TV')
                break;
            case 'vip.1905.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    if(config.playhref.indexOf("vip.1905.com/play/")!=-1){
                        ControllerVideo.addbtn();
                    }else{
                        ControllerVideo.addmobbtn();
                    }
                }
                console.log('已进入1905电影网')
                break;
            case 'v.pptv.com':
                if(commonFunction.GMgetValue("videosetting")===1){
                    ControllerVideo.addbtn();
                }
                console.log('已进入PPTV')
                break;
            case 'laisoyiba.com':
                var jconfirm = commonFunction.Commonsetinterval(".jconfirm-scrollpane");
                jconfirm.then(function(e){
                    e.parentNode.removeChild(e);
                });
                break;
            case 'm.v.qq.com':
                if(config.playhref.indexOf('/play') > -1||config.playhref.indexOf('/cover') > -1){
                    ControllerVideo.addmobbtn();
                    commonFunction.setItem("playwork","1");
                    var Poster = commonFunction.Commonsetinterval("#vipPosterContent");
                    Poster.then(function(Posternode){
                        Posternode.parentNode.removeChild(Posternode);
                    });
                    var at = commonFunction.Commonsetinterval(".at-app-banner");
                    at.then(function(atnode){
                        atnode.parentNode.removeChild(atnode);
                    });
                    console.log('已进入手机腾讯');
                }
                break;
            case 'm.youku.com':
                var callEnd_box = commonFunction.Commonsetinterval(".callEnd_box");
                callEnd_box.then(function(callEnd_boxnode){
                    callEnd_boxnode.parentNode.removeChild(callEnd_boxnode);
                });
                ControllerVideo.addmobbtn();
                console.log('已进入手机优酷');
                break;
            case 'm.iqiyi.com':
                ControllerVideo.addmobbtn();
                commonFunction.setIntervalhost();
                console.log('已进入手机爱奇艺');
                break;
            case 'm.mgtv.com':
                var mg = commonFunction.Commonsetinterval(".mg-down-btn");
                mg.then(function(mgnode){
                    mgnode.parentNode.removeChild(mgnode);
                });
                var fixed = commonFunction.Commonsetinterval(".ad-fixed-bar");
                fixed.then(function(fixednode){
                    fixednode.parentNode.removeChild(fixednode);
                });
                ControllerVideo.addmobbtn();
                commonFunction.setItem("playwork","1");
                console.log('已进入手机芒果TV');
                break;
            case 'm.bilibili.com':
                if (config.playhref.indexOf("m.bilibili.com/bangumi/play") != -1) {
                    ControllerVideo.addmobbtn();
                    commonFunction.setIntervalhost();
                }
                console.log('已进入手机bilibili');
                break;
            case 'm.le.com':
                ControllerVideo.addmobbtn();
                commonFunction.setItem("playwork","1");
                console.log('已进入手机乐视TV');
                break;
            case 'm.tv.sohu.com':
                ControllerVideo.addmobbtn();
                commonFunction.setIntervalhost();
                var cover = commonFunction.Commonsetinterval(".player_film_cover");
                cover.then(function(covernode){
                    covernode.parentNode.removeChild(covernode);
                });
                console.log('已进入手机搜狐');
                break;
            case 'm.pptv.com':
                ControllerVideo.addmobbtn();
                console.log('已进入手机PPTV');
                break;
            case 'item.taobao.com':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入淘宝');
                break;
            case 's.taobao.com':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.taobaoso();
                    commonFunction.setIntervalhost();
                }
                console.log('已进入淘宝搜索');
                break;
            case 'detail.tmall.com':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入天猫');
                break;
            case 'detail.tmall.hk':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入天猫国际');
                break;
            case 'chaoshi.detail.tmall.com':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入天猫超市');
                break;

            case 'list.tmall.com':
                ControllerCoupon.tmallso();
                // setItem("playwork","1")
                console.log('已进入天猫搜索');
                break;
            case 'item.yiyaojd.com':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入京东医药');
                break;
            case 'item.jd.com':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入京东');
                break;
            case 'npcitem.jd.hk':
                if(commonFunction.GMgetValue("couponsetting")===1){
                    ControllerCoupon.Getcoupon();
                }
                if(commonFunction.GMgetValue("historysetting")===1){
                    ControllerHistory.History();
                }
                console.log('已进入京东国际');
                break;
            case 'www.douyin.com':
                console.log('已进入抖音') ;
                if(commonFunction.GMgetValue("Shortvideosetting")===1)
                {
                    ControllerShortvideo.douyinbtn();
                }
                break;
            case 'www.kuaishou.com':
                console.log('已进入快手') ;
                if(commonFunction.GMgetValue("Shortvideosetting")===1)
                {
                    ControllerShortvideo.kuaishoubtn();
                }
                break;
            case 'www.ixigua.com':
                console.log('已进入西瓜视频') ;
                if(commonFunction.GMgetValue("Shortvideosetting")===1)
                {
                    ControllerShortvideo.xiguabtn();
                    commonFunction.setIntervalhost();
                }
                break;
            case 'www.ximalaya.com':
                console.log('已进入喜马拉雅') ;
                if(commonFunction.GMgetValue("Ximalayasetting")===1)
                {
                    Controllerximalaya.addximalaya();
                    commonFunction.setIntervalhost();
                }
                break;
            case 'jiaoyupan.com':
                console.log('已进入教育盘论坛') ;
                if(commonFunction.GMgetValue("Jiaoyupansetting")===1)
                {
                    Controllerforum.jiaoyupan();
                }
                break;
            case 'max.book118.com':
                console.log('已进入原创力') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                    Controllerdocs.yuanchuangli();
                }
                
                break;
            case 'view-cache.book118.com':
                console.log('已进入原创力PPT预览') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                    Controllerdocs.yuanchuangliPPT();
                }
               
                break;
            case 'view43.book118.com':
                console.log('已进入原创力PPT预览') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                   Controllerdocs.yuanchuangliPPT();
                }
                
                break;
            case 'view44.book118.com':
                console.log('已进入原创力PPT预览') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                     Controllerdocs.yuanchuangliPPT();
                }
               
                break;
            case 'view81.book118.com':
                console.log('已进入原创力PPT预览') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                    Controllerdocs.yuanchuangliPPT();
                }
                
                break;
            case 'www.doc88.com':
                console.log('已进入道客巴巴') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                   Controllerdocs.daokebaba();
                }
                
                break;
            case 'doc.mbalib.com':
                console.log('已进入智库文库') ;
                if(commonFunction.GMgetValue("Docssetting")===1)
                {
                     Controllerdocs.zhiku();
                }
               
                break;
            case 'blog.csdn.net':
                console.log('已进入csdn') ;
                if(commonFunction.GMgetValue("Csdnsetting")===1)
                {
                    Controllercsdn.blog();
                }
                
                break;

        }

        //网站判断执行结束
    }else{
        let userhtml = '<div id="user" style="position: fixed;top: 50%;left: 50%;width: 480px;max-width: 80%;height: 468px;border-radius: 10px;background-image: url(https://static.hitv.com/pc/img/601d3ee.png),url(https://static.hitv.com/pc/img/21b00eb.png);background-position: 0 0,100% 280px;background-repeat: no-repeat;background-color: #fff;-webkit-box-shadow: 0 0 80px rgba(0,0,0,.25);box-shadow: 0 0 80px rgba(0,0,0,.25);opacity: 1;-webkit-transform: translate(-50%,-50%);-ms-transform: translate(-50%,-50%);transform: translate(-50%,-50%);z-index: 99999;">';
        if(commonFunction.IsWap() == "wap"){
            var btncss="margin: 0 20px;";
            var tybtncss="width: 130px;"
            }else{
                btncss="margin: 0 90px;";
                tybtncss="width: 180px;"
            }

        userhtml += '<div style="margin-top: 45px;color: #222;font-weight: 700;font-size: 28px;text-align: center;">脚本使用协议</div>'
        userhtml += '<div style="width: 100%;height: 220px;margin: 35px auto 40px;overflow-x: hidden;overflow-y: scroll;">'
        userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;感谢您对本脚本的信任,为了更好的使用本脚本,在此,我们郑重提醒您:</p>'
        userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">1.有能力的情况,请大家支持正版</p>'
        userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">2.本脚本仅用学习交流,请勿用于非法、商业用途,使用本脚本下载的内容请勿进行复制、传播等侵权行为</p>'
        userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">3.VIP视频解析中所用到的解析接口全部收集自互联网(源码可见),版权问题请联系相关解析接口所有者,脚本不承担相关责任</p>'
        userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">4.视频下载内容均来自平台本身API接口,不存在破解情况,如果侵权请邮件(188872170@qq.com)联系删除。</p>'
        userhtml +='<p style="margin: 0 50px 5px;color: #777;font-weight: 400;font-size: 13px;line-height: 22px;word-break: break-all;text-align: justify;">5.点击我同意后,即已代表您已经充分了解相关问题,否则后果自负,特此声明!</p></div>'
        userhtml +='<div style="display: flex;'+btncss+'justify-content: space-between;"><button style="width: 100px;height: 45px;border: none;border-radius: 25px;outline: none;color: #fff;background: #ddd;font-weight: 700;font-size: 15px;line-height: 45px;" id="bty">不同意</button> <button style="'+tybtncss+'height: 45px;border: none;border-radius: 25px;outline: none;color: #fff;background: #ffa000;background: -webkit-gradient(linear,left top,right top,from(#ff5f00),to(#ffa000));background: -webkit-linear-gradient(left,#ff5f00,#ffa000);background: -o-linear-gradient(left,#ff5f00 0,#ffa000 100%);background: linear-gradient(90deg,#ff5f00,#ffa000);font-weight: 700;font-size: 15px;line-height: 45px;" id="ty">我同意</button></div></div>'
        console.log(userhtml)
        document.body.insertAdjacentHTML('afterbegin', userhtml);


        document.querySelector("#ty").addEventListener('click',function() {
            commonFunction.GMsetValue("isuser","1");
            window.location.reload();
        })
        document.querySelector("#bty").addEventListener('click',function() {
            commonFunction.GMsetValue("isuser","0");
            document.body.removeChild(document.querySelector("#user"));
        });
    }


    //用户协议
    
    //监听网址
    // Your code here...
})();