上一主题 下一主题
ScriptCat,新一代的脚本管理器脚本站,与全世界分享你的用户脚本油猴脚本开发指南教程目录
返回列表 发新帖

VIP视频

[复制链接]

该用户从未签到

2

主题

0

回帖

7

积分

助理工程师

积分
7

新人报道

发表于 2022-5-10 10:18:10 | 显示全部楼层 | 阅读模式
安装此脚本 如何安装? 脚本问题反馈 给脚本评分 查看代码

// ==UserScript==
// @name 吴道友超帅,全网VIP视频免费破解去广告、全网音乐直接下载、知乎增强、百度网盘直接下载等多功能工具箱,功能可独立开关。长期更新,放心使用。v5.2
// @namespace lanhaha
// @version 5.2.5
// @description 吴道友超帅多功能脚本工具箱,完全免费、无广告、无需关注公众号,集合了优酷、爱奇艺、腾讯、B站(bilibili)、芒果等全网VIP视频(PC+移动端)免费破解去广告,网易云音乐、QQ音乐、酷狗、酷我、虾米、蜻蜓FM、荔枝FM、喜马拉雅等网站音乐和有声书音频免客户端下载,知乎增强(知乎视频下载、去广告、关键词屏蔽、去除侧边栏等),百度网盘直接下载,优惠券自动查询等几个自己常用的功能,且功能可独立开关。
// @author lanhaha,syhyz1990,zhmai
// @icon 
// @match ://pan.baidu.com/disk/home
// @match ://yun.baidu.com/disk/home
// @match ://pan.baidu.com/disk/main
// @match ://yun.baidu.com/disk/main
// @match ://pan.baidu.com/s
// @match ://yun.baidu.com/s
// @match ://.youku.com/
// @match
://.iqiyi.com/
// @match ://.iq.com/play/
// @match
://.le.com/ptv/vplay/
// @match ://v.qq.com/
// @match
://.tudou.com/listplay/
// @match ://.tudou.com/albumplay/
// @match
://.tudou.com/programs/view/
// @match ://.tudou.com/v
// @match
://.mgtv.com/b/
// @match ://tv.sohu.com/
// @match
://film.sohu.com/album/
// @match ://.bilibili.com/video/
// @match
://.bilibili.com/anime/
// @match ://.bilibili.com/bangumi/play/
// @match
://.bilibili.com/s/
// @match ://.pptv.com/show/
// @match
://.wasu.cn/Play/show
// @match ://v.yinyuetai.com/video/
// @match
://v.yinyuetai.com/playlist/
// @match ://item.taobao.com/
// @match ://detail.tmall.com/
// @match
://detail.tmall.hk/
// @match ://item.jd.com/
// @match
://.yiyaojd.com/
// @match ://.liangxinyao.com/
// @match
://music.163.com/
// @match
://y.qq.com/
// @match
://i.y.qq.com/
// @match
://.kugou.com/
// @match ://kuwo.cn/
// @match
://.xiami.com/
// @match ://music.taihe.com/song
// @match ://.1ting.com/player
// @match
://music.migu.cn/v
// @match
://.lizhi.fm/
// @match ://.qingting.fm/
// @match
://.ximalaya.com/
// @match ://.zhihu.com/
// @exclude
://.zhmdy.top/
// @exclude ://.eggvod.cn/*
// @connect d.pcs.baidu.com
// @connect baidu.com
// @connect baidupcs.com
// @connect youxiaohou.com
// @connect localhost
// @require https://cdn.jsdelivr.net/npm/sweetalert2@10.16.6/dist/sweetalert2.all.min.js
// @original-script https://greasyfork.org/scripts/376078
// @original-author zhmai
// @original-license GPL License
// @original-script https://github.com/syhyz1990/baiduyun/blob/master/baiduyun.user.js
// @original-author youxiaohou
// @original-license AGPL License
// @original-changes 将强制关注公众号改为非强制。
// @antifeature referral-link 此提示为GreasyFork代码规范要求含有查券功能的脚本必须添加,实际使用无任何强制跳转,代码可查,请知悉。
// @license AGPL License
// @grant GM_download
// @grant GM_openInTab
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_deleteValue
// @grant GM_xmlhttpRequest
// @grant GM_addStyle
// @grant unsafeWindow
// @grant GM_setClipboard
// @grant GM_getResourceURL
// @grant GM_getResourceText
// @grant GM_info
// @grant GM_registerMenuCommand
// @grant GM_cookie
// ==/UserScript==

(function() {
'use strict';
/--config--/
var config ={

     couponUrl:window.location.href,

     couponHost:window.location.host,

     zhmApiUrl:'https://www.eggvod.cn/',

     isMobile:/Android|webOS|iPhone|iPod|BlackBerry/i.test(navigator.userAgent),

     iconVipTop:360,

     iconVipPosition : 'left',

     iconVipWidth : 40,

     jxCodeInfo : {'in':81516699,'code':4},

     couponTimerNum : 100,//100次等于10秒

     couponWaitTime : 1500,

     iconWaitTime : 1000,

     selectedLeft:'selected',

     selectedRight:'',

    videoPlayLineAdd:GM_getValue('videoPlayLineAdd',0)
 }

var {couponUrl,
     couponHost,
     zhmApiUrl,
     isMobile,
     iconVipTop,
     iconVipPosition,
     iconVipWidth,
     jxCodeInfo,
     couponTimerNum,
     couponWaitTime,
     iconWaitTime,
     selectedLeft,
     selectedRight,
     videoPlayLineAdd
    } = config;

/*--lang--*/
var lang = {
    set:'设置',
    iconPosition:'图标位置',
    playVideo:'视频解析',
    playMusic:'音乐下载',
    zhNice:'知乎增强',
    iconHeight:'图标高度',
    iconWidth:'图标大小',
    iconLine:'水平位置',
    iconWaitTime:'等待时间',
    iconLeft:'靠左',
    iconRight:'靠右',
    tipIconHeight:'默认360,建议1~500',
    tipIconWidth:'默认40,建议20~50',
    tipErrorIconHeight:'<图标位置>中的<图标高度>应为1000以内正整数,建议1~500',
    tipErrorIconWidth:'<图标位置>中的<图标大小>应为100以内正整数,建议20~50',
    setPlayVideo:'解析设置',
    playVideoLineAdd:'添加线路',
    tipPlayVideoLineAdd:'请输入线路名称和解析地址,例:"线路六https://jx.zdy.com/?url=",每线路一行。',
    zhSet:'知乎设置',
    zhVideoClose:'屏蔽视频',
    zhVideoDownload:'视频下载',
    zhADClose:'屏蔽广告',
    zhCloseLeft:'关闭侧边栏',
    zhChangeLink:'链接直接跳转',
    zhKeywordClose:'屏蔽关键词',
    tipKeyword:'请输入关键词',
    question:'常见问题',
    qqGroup:'交流群',
    reward:'打赏',
    redReward:'红包',
    thank:'感谢',
};

/*--datas--*/
var datas = {

     getCoupon:[{isOpen:22,web:[
         {funcName:"coupon",name:"taobao",node:".J_LinkAdd",match:/item\.taobao\.com/},
         {funcName:"coupon",name:"tmall",node:"#J_LinkBasket",match:/detail\.tmall\.com/},
         {funcName:"coupon",name:"tmall",node:"#J_LinkBasket",match:/detail\.tmall\.hk/},
         {funcName:"coupon",name:"jd",node:"#choose-btns",match:/item\.jd\.com/},
         {funcName:"coupon",name:"jd",node:"#choose-btns",match:/\.yiyaojd\.com/},
     ]}],

    jxVideo:[{isOpen:GM_getValue('movieList','22'),web:[
        {funcName:"playVideo", node:"#mod_player" ,nodeType:'id' ,match:/v\.qq\.com\/x\/cover/},
        {funcName:"playVideo", node:".container-player" ,nodeType:'class', match:/v\.qq\.com\/x\/page/},
        {funcName:"playVideo", node:"#player",nodeType:'id',match:/m\.v\.qq\.com\/x\/m\/play\?cid/},
        {funcName:"playVideo", node:"#player",nodeType:'id',match:/m\.v\.qq\.com\/x\/play\.html\?cid=/},
        {funcName:"playVideo", node:"#player",nodeType:'id',match:/m\.v\.qq\.com\/play\.html\?cid\=/},

        {funcName:"playVideo", node:"#flashbox",nodeType:'id',match:/^https:\/\/www\.iqiyi\.com\/[vwa]\_/},
        {funcName:"playVideo", node:".m-video-player-wrap",nodeType:'class',match:/^https:\/\/m.iqiyi\.com\/[vwa]\_/},
        {funcName:"playVideo", node:".intl-video-wrap",nodeType:'class',match:/^https:\/\/www\.iq\.com\/play\//},

        {funcName:"playVideo", node:"#player",nodeType:'id',match:/m\.youku\.com\/alipay_video\/id_/},
        {funcName:"playVideo", node:"#player",nodeType:'id',match:/m\.youku\.com\/video\/id_/},
        {funcName:"playVideo", node:"#player",nodeType:'id',match:/v\.youku\.com\/v_show\/id_/},

        {funcName:"playVideo", node:"#bilibiliPlayer",nodeType:'id',match:/www\.bilibili\.com\/video/},
        {funcName:"playVideo", node:"#player_module",nodeType:'id',match:/www\.bilibili\.com\/bangumi/},
        {funcName:"playVideo", node:".player-container",nodeType:'class',match:/m\.bilibili\.com\/bangumi/},
        {funcName:"playVideo", node:".mplayer",nodeType:'class',match:/m\.bilibili\.com\/video\//},

        {funcName:"playVideo", node:".video-area",nodeType:'class',match:/m\.mgtv\.com\/b/},
        {funcName:"playVideo", node:"#mgtv-player-wrap",nodeType:'id',match:/mgtv\.com\/b/},

        {funcName:"playVideo", node:".x-cover-playbtn-wrap",nodeType:'class',match:/m\.tv\.sohu\.com/},
        {funcName:"playVideo", node:"#playerWrap",nodeType:'id',match:/film\.sohu\.com\/album\//},

        {funcName:"playVideo", node:"#le_playbox",nodeType:'id',match:/le\.com\/ptv\/vplay\//},
        //无单独播放页{funcName:"playVideo", node:"j-player",nodeType:'id',match:/m\.le\.com\/vplay_\//},

        {funcName:"playVideo", node:"#player",nodeType:'id',match:/play\.tudou\.com\/v_show\/id_/},

        {funcName:"playVideo", node:"#pptv_playpage_box",nodeType:'id',match:/v\.pptv\.com\/show\//},
        //{funcName:"playVideo", node:"pptv_playpage_box",nodeType:'id',match:/vip\.pptv\.com\/show\//},
        //图标未显示{funcName:"playVideo", node:"pplive-player",nodeType:'id',match:/m\.pptv\.com\/show\//},

        {funcName:"playVideo", node:"#player",nodeType:'id',match:/vip\.1905.com\/play\//},
    ]}],

    jxMusic:[{isOpen:GM_getValue('musicList','22'),web:[
        {funcName:"playMusic",name:'netease',match:/^https?:\/\/music\.163\.com\/#\/(?:song|dj)\?id/},
        {funcName:"playMusic",name:'netease',match:/^https?:\/\/y\.music\.163\.com\/m\/(?:song|dj)\?id/},
        {funcName:"playMusic",name:'netease',match:/^https?:\/\/music\.163\.com\/(?:song|dj)\?id/},
        {funcName:"playMusic",name:'qq',match:/^https?:\/\/y\.qq\.com\/n\/ryqq\/player/},
        {funcName:"playMusic",name:'kugou',match:/kugou\.com\/song\/#hash=(\S*)&album/},
        {funcName:"playMusic",name:'kuwo',match:/kuwo\.cn\/play_detail\/(\S*)/},
        {funcName:"playMusic",name:'ximalaya',match:/^https?:\/\/www\.ximalaya\.com\/sound\/(\S*)$/},
    ]}],

    playLine:[
        {"name":"纯净1","url":"https://z1.m1907.cn/?jx=","mobile":1},
        {"name":"B站1","url":"https://vip.parwix.com:4433/player/?url=","mobile":1},
        {"name":"爱豆","url":"https://jx.aidouer.net/?url=","mobile":1},
        {"name":"BL","url":"https://vip.bljiex.com/?v=","mobile":0},
        {"name":"冰豆","url":"https://api.qianqi.net/vip/?url=","mobile":0},
        {"name":"百域","url":"https://jx.618g.com/?url=","mobile":0},
        {"name":"CK","url":"https://www.ckplayer.vip/jiexi/?url=","mobile":0},
        {"name":"CHok","url":"https://www.gai4.com/?url=","mobile":1},
        {"name":"ckmov","url":"https://www.ckmov.vip/api.php?url="},
        {"name":"大幕","url":"https://jx.52damu.com/dmjx/jiexi.php?url=","mobile":0},
        {"name":"H8","url":"https://www.h8jx.com/jiexi.php?url=","mobile":0},
        {"name":"解析","url":"https://ckmov.ccyjjd.com/ckmov/?url=","mobile":0},
        {"name":"解析la","url":"https://api.jiexi.la/?url=","mobile":0},
        {"name":"LE","url":"https://lecurl.cn/?url=","mobile":0},
        {"name":"老板","url":"https://vip.laobandq.com/jiexi.php?url=","mobile":0},
        {"name":"乐多","url":"https://api.leduotv.com/wp-api/ifr.php?isDp=1&vid=","mobile":1},
        {"name":"MAO","url":"https://www.mtosz.com/m3u8.php?url=","mobile":0},
        {"name":"M3U8","url":"https://jx.m3u8.tv/jiexi/?url=","mobile":0},
        {"name":"诺诺","url":"https://www.ckmov.com/?url=","mobile":0},
        {"name":"诺讯","url":"https://www.nxflv.com/?url=","mobile":0},
        {"name":"OK","url":"https://okjx.cc/?url=","mobile":1},
        {"name":"PM","url":"https://www.playm3u8.cn/jiexi.php?url=","mobile":0},
        {"name":"盘古","url":"https://www.pangujiexi.cc/jiexi.php?url=","mobile":0},
        {"name":"奇米","url":"https://qimihe.com/?url=","mobile":0},
        {"name":"全民","url":"https://jx.blbo.cc:4433/?url=","mobile":0},
        {"name":"RDHK","url":"https://jx.rdhk.net/?v=","mobile":1},
        {"name":"人人迷","url":"https://jx.blbo.cc:4433/?url=","mobile":1},
        {"name":"思云","url":"https://jx.ap2p.cn/?url=","mobile":0},
        {"name":"思古3","url":"https://jsap.attakids.com/?url=","mobile":1},
        {"name":"淘电影","url":"https://jx.vodjx.top/vip/?url=","mobile":0},
        {"name":"听乐","url":"https://jx.dj6u.com/?url=","mobile":1},
        {"name":"维多","url":"https://jx.ivito.cn/?url=","mobile":0},
        {"name":"虾米","url":"https://jx.xmflv.com/?url=","mobile":0},
        {"name":"小蒋","url":"https://www.kpezp.cn/jlexi.php?url=","mobile":0},
        {"name":"云端","url":"https://sb.5gseo.net/?url=","mobile":0},
        {"name":"云析","url":"https://jx.yparse.com/index.php?url=","mobile":0},
        {"name":"0523","url":"https://go.yh0523.cn/y.cy?url=","mobile":0},
        {"name":"17云","url":"https://www.1717yun.com/jx/ty.php?url=","mobile":0},
        {"name":"4K","url":"https://jx.4kdv.com/?url=","mobile":1},
        {"name":"8090","url":"https://www.8090g.cn/?url=","mobile":0}
    ],

    zhNice:[{isOpen:GM_getValue('zhihuList','22'),web:[
        {funcName:'zhNice',match:/^https?:\/\/[a-z]+\.zhihu\.com/}
    ]}],

    baidu:[{isOpen:GM_getValue('baiduList','22'),web:[
        {funcName:'baidu',match:/https?:\/\/pan\.baidu\.com/}
    ]}],

   keyCode:[
       {code:48,isShift:false,value:'0'},
       {code:48,isShift:true,value:')'},
       {code:49,isShift:false,value:'1'},
       {code:49,isShift:true,value:'!'},
       {code:50,isShift:false,value:'2'},
       {code:50,isShift:true,value:'@'},
       {code:51,isShift:false,value:'3'},
       {code:51,isShift:true,value:'#'},
       {code:52,isShift:false,value:'4'},
       {code:52,isShift:true,value:'$'},
       {code:53,isShift:false,value:'5'},
       {code:53,isShift:true,value:'%'},
       {code:54,isShift:false,value:'6'},
       {code:54,isShift:true,value:'^'},
       {code:55,isShift:false,value:'7'},
       {code:55,isShift:true,value:'&'},
       {code:56,isShift:false,value:'8'},
       {code:56,isShift:true,value:'*'},
       {code:57,isShift:false,value:'9'},
       {code:57,isShift:true,value:'('},
       {code:70,isShift:false,value:'f'},
       {code:70,isShift:true,value:'F'},
       {code:74,isShift:false,value:'j'},
       {code:74,isShift:true,value:'J'},
       {code:75,isShift:false,value:'k'},
       {code:75,isShift:true,value:'K'},
       {code:76,isShift:false,value:'l'},
       {code:76,isShift:true,value:'L'},
   ]

}

var {getCoupon,jxVideo,jxMusic,playLine,zhNice,baidu,keyCode} = datas;

/*--create style--*/
var domHead = document.getElementsByTagName('head')[0];

var domStyle = document.createElement('style');

domStyle.type = 'text/css';

domStyle.rel = 'stylesheet';

/*--Class--*/
class BaseClass{

    constructor(){

        if(GM_getValue('iconPositionSetPage') != 0){

            iconVipTop = this.getCookie('iconTop')?this.getCookie('iconTop'):iconVipTop;

            iconVipPosition = this.getCookie('iconPosition')?this.getCookie('iconPosition'):iconVipPosition;

            selectedLeft = iconVipPosition=='left'?'selected':'';

            selectedRight = iconVipPosition=='right'?'selected':'';

            iconVipWidth = this.getCookie('iconWidth')?this.getCookie('iconWidth'):iconVipWidth;

            iconWaitTime = GM_getValue('iconWaitTime')?GM_getValue('iconWaitTime')*1000:iconWaitTime;

        }

        GM_registerMenuCommand("设置", () => this.menuSet());

    }

    menuSet(){

        var _this = this;

        let menuSetStyle = `
            .zhmMask{
                z-index:999999999;
                background-color:#000;
                position: fixed;top: 0;right: 0;bottom: 0;left: 0;
                opacity:0.8;
            }
            .wrap-box{
                z-index:1000000000;
                position:fixed;;top: 50%;left: 50%;transform: translate(-50%, -200px);
                width: 300px;
                color: #555;
                background-color: #fff;
                border-radius: 5px;
                overflow:hidden;
                font:16px numFont,PingFangSC-Regular,Tahoma,Microsoft Yahei,sans-serif !important;
                font-weight:400 !important;
            }
            .setWrapHead{
                background-color:#f24443;height:40px;color:#fff;text-align:center;line-height:40px;
            }
            .setWrapLi{
                margin:0px;padding:0px;
            }
            .setWrapLi li{
                background-color: #fff;
                border-bottom:1px solid #eee;
                margin:0px !important;
                padding:12px 20px;
                display: flex;
                justify-content: space-between;align-items: center;
                list-style: none;
            }

            .setWrapLiContent{
                display: flex;justify-content: space-between;align-items: center;
            }
            .setWrapSave{
                position:absolute;top:-2px;right:10px;font-size:24px;cursor:pointer
            }
            .iconSetFoot{
                position:absolute;bottom:0px;padding:10px 20px;width:100%;
            z-index:1000000009;background:#fef9ef;
            }
            .iconSetFootLi{
                margin:0px;padding:0px;
            }

            .iconSetFootLi li{
                display: inline-flex;
                padding:0px 2px;
                justify-content: space-between;align-items: center;
                font-size: 12px;
            }
            .iconSetFootLi li a{
                color:#555;
            }
            .iconSetFootLi a:hover {
                color:#fe6d73;
            }
            .iconSetPage{
                z-index:1000000001;
                position:absolute;top:0px;left:300px;
                background:#fff;
                width:300px;
                height:100%;
            }
            .iconSetUlHead{
            padding:0px;
            margin:0px;
            }
            .iconSetPageHead{
                border-bottom:1px solid #ccc;
                height:40px;
                line-height:40px;
                display: flex;
                justify-content: space-between;
                align-items: center;
                background-color:#fe6d73;
                color:#fff;
                font-size: 15px;
            }
            .iconSetPageLi{
                margin:0px;padding:0px;
            }
            .iconSetPageLi li{
                list-style: none;
                padding:8px 20px;
            }
            .zhihuSetPage{
                z-index:1000000002;position:absolute;top:0px;left:300px;background:#fff;width:300px;height:100%;
            }
            .iconSetPageInput{
                display: flex !important;justify-content: space-between;align-items: center;
            }
            .zhihuSetPageLi{
                margin:0px;padding:0px;
            }
            .zhihuSetPageLi li{
                border-bottom:1px solid #ccc;padding:12px 20px;
            }
            .zhihuSetPageContent{
                display: flex !important;justify-content: space-between;align-items: center;
            }
            li:last-child{
                border-bottom:none;
            }
            .circular{
                width: 40px;height: 20px;border-radius: 16px;transition: .3s;cursor: pointer;box-shadow: 0 0 3px #999 inset;
            }
            .round-button{
                width: 20px;height: 20px;;border-radius: 50%;box-shadow: 0 1px 5px rgba(0,0,0,.5);transition: .3s;position: relative;
            }
            .back{
                border: solid #FFF; border-width: 0 3px 3px 0; display: inline-block; padding: 3px;transform: rotate(135deg);  -webkit-transform: rotate(135deg);margin-left:10px;cursor:pointer;
            }
            .to-right{
                margin-left:20px; display: inline-block; padding: 3px;transform: rotate(-45deg); -webkit-transform: rotate(-45deg);cursor:pointer;

            }
            .iconSetSave{
                font-size:24px;cursor:pointer;margin-right:5px;margin-bottom:4px;color:#FFF;
            }
            .zhm_set_page{
                z-index:1000000003;
                position:absolute;
                top:0px;left:300px;
                background:#fff;
                width:300px;
                height:100%;
            }
            .zhm_set_page_header{
                border-bottom:1px solid #ccc;
                height:40px;
                line-height:40px;
                display: flex;
                justify-content: space-between;
                align-items: center;
                background-color:#fe6d73;
                color:#fff;
                font-size: 15px;
            }
            .zhm_set_page_content{
                display: flex !important;justify-content: space-between;align-items: center;
            }
            .zhm_set_page_list{
                margin:0px;padding:0px;
            }
            .zhm_set_page_list li{
                /*border-bottom:1px solid #ccc;*/
                padding:12px 20px;
            }
            /*-form-*/
            :root {
                --base-color: #434a56;
                --white-color-primary: #f7f8f8;
                --white-color-secondary: #fefefe;
                --gray-color-primary: #c2c2c2;
                --gray-color-secondary: #c2c2c2;
                --gray-color-tertiary: #676f79;
                --active-color: #227c9d;
                --valid-color: #c2c2c2;
                --invalid-color: #f72f47;
                --invalid-icon: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%3E%20%3Cpath%20d%3D%22M13.41%2012l4.3-4.29a1%201%200%201%200-1.42-1.42L12%2010.59l-4.29-4.3a1%201%200%200%200-1.42%201.42l4.3%204.29-4.3%204.29a1%201%200%200%200%200%201.42%201%201%200%200%200%201.42%200l4.29-4.3%204.29%204.3a1%201%200%200%200%201.42%200%201%201%200%200%200%200-1.42z%22%20fill%3D%22%23f72f47%22%20%2F%3E%3C%2Fsvg%3E");
            }
            .text-input {
                font-size: 16px;
                position: relative;
                right:0px;
                z-index: 0;
            }
            .text-input__body {
                -webkit-appearance: none;
                -moz-appearance: none;
                appearance: none;
                background-color: transparent;
                border: 1px solid var(--gray-color-primary);
                border-radius: 3px;
                height: 1.7em;
                line-height: 1.7;
                overflow: hidden;
                padding: 2px 1em;
                text-overflow: ellipsis;
                transition: background-color 0.3s;
                width:55%;
                font-size:14px;
            }
            .text-input__body:-ms-input-placeholder {
                color: var(--gray-color-secondary);
            }
            .text-input__body::-moz-placeholder {
                color: var(--gray-color-secondary);
            }
            .text-input__body::placeholder {
                color: var(--gray-color-secondary);
            }
            *, ::after, ::before {
            box-sizing: initial !important;
            }
            .text-input__body[data-is-valid] {
                padding-right: 1em;
            }
            .text-input__body[data-is-valid=true] {
                border-color: var(--valid-color);
            }
            .text-input__body[data-is-valid=false] {
                border-color: var(--invalid-color);
                box-shadow: inset 0 0 0 1px var(--invalid-color);
            }
            .text-input__body:focus {
                border-color: var(--active-color);
                box-shadow: inset 0 0 0 1px var(--active-color);
                outline: none;
            }
            .text-input__body:-webkit-autofill {
                transition-delay: 9999s;
                -webkit-transition-property: background-color;
                transition-property: background-color;
            }
            .text-input__validator {
                background-position: right 0.5em center;
                background-repeat: no-repeat;
                background-size: 1.5em;
                display: inline-block;
                height: 100%;
                left: 0;
                position: absolute;
                top: 0;
                width: 100%;
                z-index: -1;
            }
            .text-input__body[data-is-valid=false] + .text-input__validator {
                background-image: var(--invalid-icon);
            }
            .select-box {
                box-sizing: inherit;
                font-size: 16px;
                position: relative;
                transition: background-color 0.5s ease-out;
                width:90px;
            }
            .select-box::after {
                border-color: var(--gray-color-secondary) transparent transparent transparent;
                border-style: solid;
                border-width: 6px 4px 0;
                bottom: 0;
                content: "";
                display: inline-block;
                height: 0;
                margin: auto 0;
                pointer-events: none;
                position: absolute;
                right: -72px;
                top: 0;
                width: 0;
                z-index: 1;
            }
            .select-box__body {
                box-sizing: inherit;
                -webkit-appearance: none;
                -moz-appearance: none;
                appearance: none;
                background-color: transparent;
                border: 1px solid var(--gray-color-primary);
                border-radius: 3px;
                cursor: pointer;
                height: 1.7em;
                line-height: 1.7;
                padding-left: 1em;
                padding-right: calc(1em + 16px);
                width: 140%;
                font-size:14px;
                padding-top:2px;
                padding-bottom:2px;
            }
            .select-box__body[data-is-valid=true] {
                border-color: var(--valid-color);
                box-shadow: inset 0 0 0 1px var(--valid-color);
            }
            .select-box__body[data-is-valid=false] {
                border-color: var(--invalid-color);
                box-shadow: inset 0 0 0 1px var(--invalid-color);
            }
            .select-box__body.focus-visible {
                border-color: var(--active-color);
                box-shadow: inset 0 0 0 1px var(--active-color);
                outline: none;
            }
            .select-box__body:-webkit-autofill {
                transition-delay: 9999s;
                -webkit-transition-property: background-color;
                transition-property: background-color;
            }
            .textarea__body {
                -webkit-appearance: none;
                -moz-appearance: none;
                appearance: none;
                background-color: transparent;
                border: 1px solid var(--gray-color-primary);
                border-radius: 0;
                box-sizing: border-box;
                font: inherit;
                left: 0;
                letter-spacing: inherit;
                overflow: hidden;
                padding: 1em;
                position: absolute;
                resize: none;
                top: 0;
                transition: background-color 0.5s ease-out;
                width: 100%;
                }
            .textarea__body:only-child {
                position: relative;
                resize: vertical;
            }
            .textarea__body:focus {
                border-color: var(--active-color);
                box-shadow: inset 0 0 0 1px var(--active-color);
                outline: none;
            }
            .textarea__body[data-is-valid=true] {
                border-color: var(--valid-color);
                box-shadow: inset 0 0 0 1px var(--valid-color);
            }
            .textarea__body[data-is-valid=false] {
                border-color: var(--invalid-color);
                box-shadow: inset 0 0 0 1px var(--invalid-color);
            }

            .textarea ._dummy-box {
                border: 1px solid;
                box-sizing: border-box;
                min-height: 240px;
                overflow: hidden;
                overflow-wrap: break-word;
                padding: 1em;
                visibility: hidden;
                white-space: pre-wrap;
                word-wrap: break-word;
            }
            .toLeftMove{
                nimation:moveToLeft 0.5s infinite;
                -webkit-animation:moveToLeft 0.5s infinite; /*Safari and Chrome*/
                animation-iteration-count:1;
                animation-fill-mode: forwards;
            }

            @keyframes moveToLeft{
                from {left:200px;}
                to {left:0px;}
            }

            @-webkit-keyframes moveToLeft /*Safari and Chrome*/{
                from {left:200px;}
                to {left:0px;}
            }

            .toRightMove{
                nimation:moveToRight 2s infinite;
                -webkit-animation:moveToRight 2s infinite; /*Safari and Chrome*/
                animation-iteration-count:1;
                animation-fill-mode: forwards;
            }
            @keyframes moveToRight{
                from {left:0px;}
                to {left:2000px;}
            }

            @-webkit-keyframes moveToRight /*Safari and Chrome*/{
                from {left:0px;}
                to {left:200px;}
            }
        `;

        domStyle .appendChild(document.createTextNode(menuSetStyle));

        domHead.appendChild(domStyle);

        var setListJson= [{'listName':lang.iconPosition,'setListID':'iconPositionSetPage','setPageID':'movieIconSetPage'},{'listName':lang.playVideo,'setListID':'movieList','setPageID':'movieVideoSetPage'},{'listName':lang.playMusic,'setListID':'musicList','setPageID':''},{'listName':lang.zhNice,'setListID':'zhihuList','setPageID':'zhihuIconSetPage'}];

        var zhihuOptionJson = [{'optionName':lang.zhVideoClose,'optionID':'removeVideo','default':'0'},{'optionName':lang.zhVideoDownload,'optionID':'downloadVideo','default':'22'},{'optionName':lang.zhADClose,'optionID':'removeAD','default':'22'},{'optionName':lang.zhCloseLeft,'optionID':'removeRight','default':'0'},{'optionName':lang.zhChangeLink,'optionID':'changeLink','default':'22'},{'optionName':lang.zhKeywordClose,'optionID':'removeKeyword','default':'0'}];

        var playVideoOptionJson = [{'optionName':'添加线路','optionID':'videoPlayLineAdd','default':videoPlayLineAdd}];

        var setHtml = "<div id='setMask' class='zhmMask'></div>";

        setHtml +="<div class='wrap-box' id='setWrap'>";

        setHtml +="<div class='iconSetPage' id='movieIconSetPage'>";

        setHtml +="<ul class='iconSetUlHead'><li class='iconSetPageHead'><span class='back'></span><span>"+lang.iconPosition+"</span><span class='iconSetSave'>×</span></li></ul>";

        setHtml +="<ul class='iconSetPageLi'>";

        setHtml +="<li>"+lang.iconHeight+":<span class='text-input'><input class='text-input__body' id='iconTop' value='"+iconVipTop+"' placeholder='"+lang.tipIconHeight+"'><span class='text-input__validator'></span></span></li>";

        setHtml += "<li  style='display: inline-flex;'><span style='padding-top:4px;'>"+lang.iconLine+":</span><div class='select-box'><select class='select-box__body' id='iconPosition'>";

        setHtml +="<option value='left' "+selectedLeft+">"+lang.iconLeft+"</option><option value='right' "+selectedRight+">"+lang.iconRight+"</option>";

        setHtml +="</select></div></li>"

        setHtml +="<li>"+lang.iconWidth+":<span class='text-input'><input class='text-input__body' id='iconWidth' value='"+iconVipWidth+"' placeholder='"+lang.tipIconWidth+"'><span class='text-input__validator'></span></span></li>";

        setHtml += "<li  style='display: inline-flex;'><span style='padding-top:4px;'>"+lang.iconWaitTime+":</span><div class='select-box'><select class='select-box__body' id='iconWaitTime'>";

        for(let i =1;i<=8;i++){

            let iconSelected = GM_getValue('iconWaitTime')==i/2?'selected':'';

            setHtml +="<option value="+i/2+" "+iconSelected+">"+i/2+"秒</option>";

        }

        setHtml +="</select></div></li>"

        setHtml +="</ul></div>";

        setHtml +="<div class='zhm_set_page' id='movieVideoSetPage'>";

        setHtml +="<ul class='iconSetUlHead'><li class='zhm_set_page_header'><span class='back'></span><span>"+lang.setPlayVideo+"</span><span  class='iconSetSave'>×</li></ul>";

        setHtml +="<ul class='zhm_set_page_list'>";

        for(let i=0;i<playVideoOptionJson.length;i++){

            let backColor,switchBackCorlor,display;

            let optionValue = GM_getValue(playVideoOptionJson[i].optionID,playVideoOptionJson[i].default);

            if(optionValue != '22'){

                backColor = '#fff';

                switchBackCorlor = '#FFF';

                display = 'none';

            }else{

                backColor = '#fe6d73';

                switchBackCorlor = '#FFE5E5';

                display = 'block';

            }

            setHtml +="<li>";

            setHtml +="<div class='zhm_set_page_content'>";

            setHtml += "<span>"+lang.playVideoLineAdd+"</span>";

            setHtml +="<div class='circular' style='background-color:"+switchBackCorlor+"' id='"+playVideoOptionJson[i].optionID+"'>";

            setHtml +="<div class='round-button' style='background: "+backColor+"; left: "+optionValue+"px;'></div>";

            setHtml += "</div></div>";

            setHtml +="<div class='form__textarea'>";

            setHtml +="<div class='textarea js-flexible-textarea' style='margin-top: 10px; display: "+display+"; padding: 5px 0px;' id='videoPlayLineAddTextarea'>";

            setHtml +="<textarea rows='5' class='textarea__body' placeholder='"+lang.tipPlayVideoLineAdd+"' style='width:250px;font-size:14px;padding:4px;resize:none;' id='playVideoLineTextarea'>"+GM_getValue('playVideoLineText','')+"</textarea>";

            setHtml +="</div></div></li>";
        }

        setHtml +="</ul>"

        setHtml +="</div>"

        setHtml +="<div class='zhihuSetPage' id='zhihuIconSetPage'>";

        setHtml +="<ul class='iconSetUlHead'><li class='iconSetPageHead'><span class='back'></span><span>"+lang.zhSet+"</span><span  class='iconSetSave'>×</li></ul>";

        setHtml +="<ul class='zhihuSetPageLi'>";

        for(var optionN=0;optionN<zhihuOptionJson.length;optionN++){

            let backColor,switchBackCorlor;

            let optionValue = GM_getValue(zhihuOptionJson[optionN].optionID,zhihuOptionJson[optionN].default);

            if(optionValue != '22'){

                backColor = '#fff';

                switchBackCorlor = '#FFF';

            }else{

                backColor = '#fe6d73';

                switchBackCorlor = '#FFE5E5';

            }

            setHtml +="<li ><div class='zhihuSetPageContent'><span>"+zhihuOptionJson[optionN].optionName+"</span>";

            setHtml +="<div class='circular' style='background-color: "+switchBackCorlor+";' id="+zhihuOptionJson[optionN].optionID+"><div class='round-button' style='background: "+backColor+";left: "+optionValue+"px;'></div></div></div>";

            if(zhihuOptionJson[optionN].optionID == 'removeKeyword'){

                var keywordShow;

                if(GM_getValue('removeKeyword','0') == '22'){

                    keywordShow = 'block';

                }else{
                    keywordShow = 'none';
                }

                setHtml +="<div style='margin-top:10px;display:"+keywordShow+";padding:5px 0px;' id='zhihuKeyword'><span class='text-input'><input value='"+GM_getValue('inputZhKeyword','')+"' id='inputZhKeyword' class='text-input__body' placeholder='"+lang.tipKeyword+"' style='width:88%'><span></div>";
            }
            setHtml +="</li>";
        }

        setHtml +="</ul></div>";

        setHtml +="<ul class='iconSetUlHead'><li class='iconSetPageHead'><span></span><span>"+lang.set+"</span><span class='iconSetSave'>×</span></li></ul>";

        setHtml +="<ul class='setWrapLi'>";

        for(var setN=0;setN<setListJson.length;setN++){

            var listValue = GM_getValue(setListJson[setN].setListID,'22');

            let backColor,arrowColor,switchBackCorlor;

            if(listValue != 22){
                backColor = '#fff';
                arrowColor= '#EEE';
                switchBackCorlor = '#FFF';

            }else{
                backColor = '#fe6d73';
                arrowColor = '#CCC';
                switchBackCorlor = '#FFE5E5';
            }

            if(setListJson[setN].setPageID == ''){
                arrowColor = '#EEE';
            };
            setHtml +="<li><span>"+setListJson[setN].listName+"</span>";

            setHtml +="<div class='setWrapLiContent'>";

            setHtml +="<div class='circular' id='"+setListJson[setN].setListID+"' style='background-color: "+switchBackCorlor+";'><div class='round-button' style='background: "+backColor+";left: "+listValue+"px'></div></div>";

            setHtml +="<span class='to-right' data='"+setListJson[setN].setPageID+"' style='border: solid "+arrowColor+"; border-width: 0 3px 3px 0;'></span></div></li>";
        }

        setHtml +="</ul>";

        setHtml +="<div style='height:180px;'></div>";

        setHtml +="<div class='iconSetFoot' style=''>";

        setHtml +="<ul class='iconSetFootLi'>";

        setHtml +="<li><a  target='_blank'>"+lang.question+"</a></li>・<li><a  target='_blank'>交流群</a></li>・<li><a  target='_blank'>"+lang.reward+"</a></li>・<li><a  target='_blank'>"+lang.redReward+"</a></li>・<li><a  target='_blank'>"+lang.thank+"</a></li>";

        setHtml +='</ul>';

        setHtml +='</div>';

        setHtml += "</div>";

        if(document.querySelector('#setMask')) return;

        this.createElement('div','zhmMenu');

        let zhmMenu = document.getElementById('zhmMenu');

        zhmMenu.innerHTML = setHtml;

        let timerZhmIcon = setInterval(function(){

            if (document.querySelector('#zhmMenu')){

                clearInterval(timerZhmIcon); // 取消定时器

                let circular = document.querySelectorAll('.circular');

                circular.forEach(function(item){

                    item.addEventListener('click', function(e){

                        let buttonStyle = item.children[0].style;

                        let left = buttonStyle.left;

                        left = parseInt(left);

                        let listLeftValue;

                        if(left==0){

                            buttonStyle.left = '22px';

                            buttonStyle.background = '#fe6d73';

                            item.style.background='#ffE5E5';

                            if(item.nextSibling && item.nextSibling.getAttribute('data')){

                                item.nextSibling.setAttribute('style','border: solid #ccc;border-width: 0 3px 3px 0;')
                            }

                            listLeftValue = 22;

                        }else{

                            buttonStyle.left = '0px';

                            buttonStyle.background = '#fff';

                            item.style.background='#fff';

                            if(item.nextSibling){

                                item.nextSibling.setAttribute('style','border: solid #EEE;border-width: 0 3px 3px 0;')

                            }

                            listLeftValue = 0;
                        }

                        let setListID = item.id;

                        if(setListID == 'removeKeyword' && listLeftValue==22){

                            document.querySelector('#zhihuKeyword').style.display='block';
                        }

                        if(setListID == 'removeKeyword' && listLeftValue==0){

                            document.querySelector('#zhihuKeyword').style.display='none';
                        }

                        if(setListID == 'videoPlayLineAdd' && listLeftValue==22){

                            document.querySelector('#videoPlayLineAddTextarea').style.display='block';
                        }

                        if(setListID == 'videoPlayLineAdd' && listLeftValue==0){

                            document.querySelector('#videoPlayLineAddTextarea').style.display='none';
                        }

                        GM_setValue(setListID,listLeftValue);

                    })

                });

                let toRight = document.querySelectorAll('.to-right');

                toRight.forEach(function(item){

                    item.addEventListener('click', function(e){

                        let left = item.previousSibling.children[0].style.left;

                        left = parseInt(left);

                        if(left != 22) return;

                        let setPageID = item.getAttribute('data');

                        let pageId = document.getElementById(setPageID);

                        pageId.className='iconSetPage toLeftMove';

                    })

                })

                let toBack = document.querySelectorAll('.back');

                toBack.forEach(function(item){

                    item.addEventListener('click', function(e){

                        let parentDom = item.parentNode.parentNode.parentNode;

                        parentDom.className='iconSetPage toRightMove'

                    })

                })

                let setSave = document.querySelectorAll('.iconSetSave');

                setSave.forEach(function(item){

                    item.addEventListener('click',()=>{

                        let iconTop = document.getElementById('iconTop').value;

                        let iconPosition = document.getElementById('iconPosition').value;

                        let iconWidth = document.getElementById('iconWidth').value;

                        let iconWaitTime = document.getElementById('iconWaitTime').value;

                        let playVideoLineText = document.querySelector('#playVideoLineTextarea').value;

                        let playVideoLineLeft = document.querySelector('#videoPlayLineAdd').children[0].style.left;

                        let inputZhKeyword = document.getElementById('inputZhKeyword').value;

                        if(iconTop != ''){

                            if(!(/(^[1-9][0-9]{0,2}$)/.test(iconTop))){

                                alert(lang.tipErrorIconHeight);

                                return false;
                            }

                            _this.setCookie('iconTop',iconTop,30)
                        }

                        if(iconPosition != ''){

                            _this.setCookie('iconPosition',iconPosition,30)
                        }

                        if(iconWaitTime != ''){

                            GM_setValue('iconWaitTime',iconWaitTime);
                        }

                        if(iconWidth !=''){

                            if(!(/(^([1-9][0-9]?)$)/.test(iconWidth))){

                                alert(lang.tipErrorIconWidth);

                                return false;
                            }

                            _this.setCookie('iconWidth',iconWidth,30);
                        }

                        if(GM_getValue('videoPlayLineAdd') == 22){

                            if(playVideoLineText){

                                let lineObj = _this.getLine(playVideoLineText);

                                if(lineObj.length>0){

                                    GM_setValue('playVideoLineText',playVideoLineText);

                                }else{
                                    alert('线路输入不正确');
                                    return;
                                }

                            }else{

                                GM_setValue('playVideoLineText','');
                            }

                        }else{

                            GM_setValue('playVideoLineText',playVideoLineText);
                        }

                        if(inputZhKeyword != ''){

                            GM_setValue('inputZhKeyword',inputZhKeyword);

                        }else{

                            if(GM_getValue('inputZhKeyword')){

                                GM_deleteValue('inputZhKeyword');
                            }

                        }

                        history.go(0);
                    })
                })

                document.getElementById('iconTop').addEventListener('change',function(){

                    let iconTop = this.value;

                    if(!(/(^[1-9]\d*$)/.test(iconTop))){

                        this.setAttribute('data-is-valid','false')

                    }else{

                        this.setAttribute('data-is-valid','true')
                    }

                    return false;

                })

                document.getElementById('iconWidth').addEventListener('change',function(){

                    let iconWidth = this.value;

                    if(!(/(^[1-9]\d*$)/.test(iconWidth))){

                        this.setAttribute('data-is-valid','false')

                    }else{

                        this.setAttribute('data-is-valid','true')
                    }

                    return false;

                })
                //腾讯视频快捷键冲突
                if(couponUrl.match(/v\.qq\.com\/x\/cover/)){

                    let addLineText =document.querySelector('#playVideoLineTextarea');

                    addLineText.addEventListener('keydown',function(e){

                        let startPos = addLineText.selectionStart;

                        let endPos = addLineText.selectionEnd;

                        if (startPos === undefined || endPos === undefined) return;

                        keyCode.forEach(function(item){

                            if(e.keyCode == item.code && e.shiftKey==item.isShift){

                                let textValue = addLineText.value;

                                let startValue = textValue.substring(0,startPos);

                                let endValue = textValue.substring(startPos);

                                let allValue = startValue+item.value+endValue;

                                addLineText.value=allValue;

                                addLineText.selectionStart = startPos+1;

                                addLineText.selectionEnd = endPos+1;

                            }
                        })

                    })
                }
            }

        })

    }

    createElement(dom,domId){

        var rootElement = document.body;

        var newElement = document.createElement(dom);

        newElement.id = domId;

        var newElementHtmlContent = document.createTextNode('');

        rootElement.appendChild(newElement);

        newElement.appendChild(newElementHtmlContent);

    }

    request(method,url,data){

        let request = new XMLHttpRequest();

        return new Promise((resolve,reject)=>{

            request.onreadystatechange=function(){

                if(request.readyState==4){

                    if(request.status==200){

                        resolve(request.responseText);

                    }else{

                        reject(request.status);
                    }

                }
            }

            request.open(method,url);

            request.send(data);

        })

    }

    setCookie(cname,cvalue,exdays){

        var d = new Date();

        d.setTime(d.getTime()+(exdays*24*60*60*1000));

        var expires = "expires="+d.toGMTString();

        document.cookie = cname+"="+cvalue+"; "+expires;
    }

    getCookie(cname){
        var name = cname + "=";
        var ca = document.cookie.split(';');
        for(var i=0; i<ca.length; i++) {
            var c = ca[i].trim();
            if (c.indexOf(name)==0) { return c.substring(name.length,c.length); }
        }
        return "";
    }

    getQueryString(e) {
        var t = new RegExp("(^|&)" + e + "=([^&]*)(&|$)");
        var a = window.location.search.substr(1).match(t);
        if (a != null) return a[2];
        return "";
    }

    getUrlParams(url){
        let reg = /([^?&+#]+)=([^?&+#]+)/g;
        let obj={};
        url.replace(reg,(res,$1,$2)=>{obj[$1]=$2});
        return obj;
    }

    getLine(text){

        let textArr = text.split('\n');

        if(textArr.length > 0){

            let lineObj = [];

            let match = /^(.+)(https?:\/\/.+)$/;

            textArr.forEach(function(item){

                item = item.replace(/\s*,*/g,'');

                if(!item) return true;

                let lineMatch = item.match(match);

                if(lineMatch){

                    lineObj.push({'name':lineMatch[1].substring(0,4),'url':lineMatch[2]});

                }else{

                    lineObj=[];

                    return false;
                }

            })

            return lineObj;

        }
    }

}

class CouponClass extends BaseClass{

    constructor(){

        super();

        this.divElement = document.createElement("div");

        this.divElement.id='zhm_div_s';

    }
    taobao(){
        let node = document.querySelector('.J_LinkAdd').parentNode;

        let className = 'zhm_tab_taobao';

        this.getCouponInfo(node,className);
    }
    tmall(){

        let node = document.querySelector('#J_LinkBasket').parentNode;

        let className = 'zhm_tab_tmall';

        this.getCouponInfo(node,className);
    }
    jd(){
        setTimeout(()=>{

            let jdGoodsId = couponUrl.match(/jd\.com\/(\S*).html/);

            let node= document.querySelector('#choose-btns');

            node.after(this.divElement);

            this.request('get',`https://zuihuimai.net/vrhr/index_jd.php?goods_id=${jdGoodsId[1]}`).then((result)=>{

                document.getElementById('zhm_div_s').innerHTML = result;

            })

        },couponWaitTime)
    }
    getCouponInfo(node,className){

      setTimeout(()=>{

          let goods_id = this.getQueryString('id');

          if(!goods_id){console.log('goods_id');return};

          node.after(this.divElement);

          this.request('get',`https://www.zuihuimai.net/vrhr/index.php?goods_id=${goods_id}`).then((result)=>{

              document.getElementById('zhm_div_s').innerHTML=result;

              document.getElementById('zhm_table').className = 'zhm_tab '+className;

          })

      },couponWaitTime);
    }

}

class PlayVideoClass extends BaseClass{
    constructor(){
        super();
    }

}

class PlayMusicClass extends BaseClass{
    constructor(){
        super();
    }
}

class ZhClass extends BaseClass{

    constructor(){
        super();
    }

    removeVideo(){

        let card = document.querySelectorAll('.Feed');

        card.forEach(function(item){

            let dataZop = JSON.parse(item.getAttribute('data-za-extra-module'));

            let video = dataZop.card.content.video_id;

            if(video){

                item.parentNode.style='display:none;';

            }
        })

    }
    removeAD(){

        let zhHideAD = `.Pc-card{display:none !important;}.TopstoryItem--advertCard{display:none !important}`;

        domStyle .appendChild(document.createTextNode(zhHideAD));

        domHead.appendChild(domStyle);

    }
    downloadVideo(){

        window.addEventListener('click',(e)=>{

            if(e.target.innerText == '下载'){

                var videoId;

                if(document.querySelector('.ZVideo-player')){

                    let zVideo = document.querySelector('.ZVideo');

                    let videoData = JSON.parse(zVideo.getAttribute('data-za-extra-module'));

                    videoId = videoData.card.content.video_id;

                }else{

                    let videoUrl = window.location.href;

                    let videoObj = videoUrl.split('?');

                    videoId = videoObj[0].split('/').pop();
                }

                let url = 'https://lens.zhihu.com/api/v4/videos/'+videoId;

                this.request('get',url).then((result)=>{

                    let data = JSON.parse(result);

                    if(data.playlist != undefined){

                        let play_url = data.playlist.LD.play_url;

                        let videoName = videoId+".mp4";

                        GM_download(play_url,videoName);

                    }else{

                        alert('下载失败!');

                    }
                });
            }
        })

        document.addEventListener('DOMNodeInserted',(e) => {

            if(!e.relatedNode.querySelector) return;

            var playBar = e.relatedNode.querySelector(':scope > div:last-child > div:first-child > div:nth-of-type(2)');

            if(!playBar || playBar.querySelector('.zhmDownload')) return;

            var playBut = playBar.querySelector(':scope > div:last-child');

            if(!playBut) return;

            var playButLi = playBut.querySelector('div:first-child');

            if(!playButLi) return;

            var downloadBut = playButLi.cloneNode(true);

            downloadBut.className = playButLi.className + ' zhmDownload';

            if(!downloadBut.querySelector('._1tg8oir')) return;

            downloadBut.querySelector('._1tg8oir').innerText='下载';

            playButLi.before(downloadBut);

        })

    }

    removeRight(){

        let zhFullScreen = `.GlobalSideBar {display: none !important;}
        .Question-sideColumn{display:none !important}
        .Topstory-mainColumn{width:100% !important}
        .Question-mainColumn{width:1000px !important}
        .css-cazg48{margin: 0px 16px 0px 0px !important;}
        .QuestionWaiting-mainColumn{width:100% !important;}
        .css-1j5d3ll{padding-left:10px;}
        .css-yhjwoe{justify-content: space-between !important;}
        `;
        domStyle .appendChild(document.createTextNode(zhFullScreen));

        domHead.appendChild(domStyle);
    }
    changeLink(){

        if(couponUrl.indexOf('target') != -1){

            let obj = this.getUrlParams(couponUrl);

            if(obj.target == undefined) return;

            let link = decodeURIComponent(obj.target);

            location.href=link;
        }
    }
    removeKeyword(){

        var GMKeyword = GM_getValue('inputZhKeyword','0');

        if(GMKeyword == '0' || GMKeyword == '') return;

        let keyword = GMKeyword.split(',');

        let content = document.querySelectorAll('.ContentItem');

         keyword.forEach(function(item){

             content.forEach(function(value){

                 let dataZop = JSON.parse(value.getAttribute('data-zop'));

                 if(dataZop.title.indexOf(item) != -1){

                     let itemCard = value.parentNode.parentNode.parentNode;

                     let itemCardClass= itemCard.className;

                    if(itemCardClass.indexOf('TopstoryItem-isRecommend') != -1){

                        itemCard.style='display:none';
                    }
                 }

             })
         })
    }
}

var allWeb = [...getCoupon,...jxVideo,...jxMusic,...zhNice,...baidu];

var nowWeb=[];

allWeb.forEach(function(item){

    if(item.isOpen == 0) return true;

    item.web.forEach(function(val){

        let result = couponUrl.match(val.match);

        if(result){

            nowWeb.push(val);

        }
    })

})

if(nowWeb.length==0){
    let baseClass = new BaseClass();
    console.log('没有匹配该网站或该模块已关闭');return;
}

let {funcName,match:nowMatch,node:nowNode,name:nowName} = nowWeb[0];

/*--listener click 选集跳转--*/

if(funcName=='playVideo'){

    window.addEventListener('click', function(e){

        var objLink = {};

        e.path.forEach(function(item){

            if(item.href){

                objLink.href = item.href?item.href:'';

                objLink.target = item.target?item.target:'';

                return;
            }

        })

        if(objLink.href){

            if(objLink.target != '_blank'){

               location.href = objLink.href;

            }

        }
    })
}

switch(funcName){
    case 'coupon':
        var couponClass = new CouponClass();
        couponFunc();
        break;
    case 'playVideo':
        var playVideoClass = new PlayVideoClass();
        playVideoFunc();
        break;
    case 'playMusic':
        var playMusicClass = new PlayMusicClass();
        playMusicFunc();
        break;
    case 'zhNice':
        var zhClass = new ZhClass();
        zhNiceFunc();
        break;
    case 'baidu':
        baiduFunc();
        break;
}

function couponFunc(){

    var couponStyle =`
        .zhm_tab{width:400px;border:1px solid #f40;border-collapse:collapse;}
        .zhm_tab tr:nth-of-type(1){font-size:14px;text-align:center;}
        .zhm_tab tr th{padding:10px;20px;text-align:center;}
        .zhm_tab tr td{padding:10px;20px;text-align:center;font-size:14px;}
        .zhm_tab tr td a{ text-decoration:none;}

        .zhm_tab_taobao{margin-top:50px;}
        .zhm_tab_taobao tr:nth-of-type(1){background-color:#f40;color:#FFF;}
        .zhm_tab_taobao tr td{border:1px solid #e6602d;color:#e6602d;}
        .zhm_tab_taobao tr td a{color:#e6602d;}
        .zhm_tab_taobao tr td a b{color:#e6602d;font-weight:800}

        .zhm_tab_jd {margin-top:0px;margin-bottom:20px;}
        .zhm_tab_jd tr:nth-of-type(1){background-color:#e4393c;color:#FFF;}
        .zhm_tab_jd tr td{border:1px solid #e4393c;color:#e4393c;}
        .zhm_tab_jd tr td a{color:#e4393c;}

        .zhm_tab_tmall {margin-top:50px;}
        .zhm_tab_tmall tr:nth-of-type(1){background-color:#ff0036;color:#FFF;}
        .zhm_tab_tmall tr td{border:1px solid #ff0036;color:#ff0036;}
        .zhm_tab_tmall tr td a{color:#ff0036;}
    `;

    domStyle .appendChild(document.createTextNode(couponStyle));

    domHead.appendChild(domStyle);

    let n=0;

    let couponTimer = setInterval(function(){

        n++;

        let pageNode = document.querySelector(nowNode)

        if(pageNode){

            clearInterval(couponTimer);

            couponClass[nowName]();

        }else{

            if(n==couponTimerNum) clearInterval(couponTimer);
        }

    },100)
}

function playVideoFunc(){

    if(isMobile){

        playLine = playLine.filter(function(item){

            return item.mobile;

        })
    }
    //css
    let playVideoStyle = `
        .zhm_play_vidoe_icon{
            padding-top:2px;cursor:pointer;
            z-index:9999999;
            display:block;
            position:fixed;${iconVipPosition}:0px;top:${iconVipTop}px;text-align:center;overflow:visible
        }
        .zhm_play_video_wrap{
            position:fixed;${iconVipPosition}:${iconVipWidth}px;top:${iconVipTop}px;
            z-index:9999999;
            overflow: hidden;
            width:300px;
        }
        .zhm_play_video_line{
            width:320px;
            height:316px;
            overflow-y:scroll;
            overflow-x:hidden;
        }
        .zhm_play_vide_line_ul{
            width:300px;
            display: flex;
            justify-content: flex-start;
            flex-flow: row wrap;
            list-style: none;
            padding:0px;
            margin:0px;

        }
        .zhm_play_video_line_ul_li{
            padding:4px 0px;
            margin:2px;
            width:30%;
            color:#FFF;
            text-align:center;
            background-color:#f24443;
            box-shadow:0px 0px 10px #fff;
            font-size:14px;
        }
        .zhm_play_video_line_ul_li:hover{
            color:#260033;
            background-color:#fcc0c0
        }
        .zhm_line_selected{
            color:#260033;
            background-color:#fcc0c0
        }

        .zhm_play_video_jx{
            width:100%;
            height:100%;
            z-index:999999;
            position: absolute;top:0px;padding:0px;
        }
    `;

    domStyle .appendChild(document.createTextNode(playVideoStyle));

    domHead.appendChild(domStyle);

    //custom add line

    if(GM_getValue('videoPlayLineAdd')==22 && GM_getValue('playVideoLineText')){

        let lineObj = playVideoClass.getLine(GM_getValue('playVideoLineText'));

        if(lineObj){

            playLine = [...lineObj,...playLine];
        }

    }

    //template:icon,playLine;
    let playWrapHtml = "<div href='javascript:void(0)' target='_blank' style='' class='playButton zhm_play_vidoe_icon' id='zhmlogo'><img class='iconLogo' src='' title='点击主图标弹出解析,点击右侧列表站内解析' style='width:"+iconVipWidth+"px'>";

    playWrapHtml += "<div class='playLineDiv zhm_play_video_wrap' style='display:none;'>"

    playWrapHtml += "<div class='zhm_play_video_line'>";

    playWrapHtml +="<div><ul class='zhm_play_vide_line_ul'>";

    playLine.forEach(function(item){

        let selected = '';

        if(playVideoClass.getCookie('playLineAction') == item.url){

            selected='zhm_line_selected';

        }

        playWrapHtml +=`<li class='playLineTd zhm_play_video_line_ul_li ${selected}' url='${item.url}' >${item.name}</li>`;

    })

    playWrapHtml +="</div></div></div>";

    //template:node;播放区域

    let playJxHtml = "<div class='zhm_play_video_jx'>";

    playJxHtml += "<iframe allowtransparency=true frameborder='0' scrolling='no' allowfullscreen=true allowtransparency=true name='jx_play' style='height:100%;width:100%' id='playIframe'></iframe></div>";

    //iqiyi电视剧选集处理
    if (nowNode == "#flashbox"){

        let timerIqiyiVipIcon=setInterval(function(){

            let selectItem = document.querySelectorAll('.icon-tr > img');

            if(selectItem.length > 0){

                selectItem.forEach(function(item){

                    item.parentNode.removeChild(item);

                })

            }
        })

        setTimeout(function(){

            clearInterval(timerIqiyiVipIcon);

        },300000)

    }
    //乐视选集处理
    if(nowNode == "#le_playbox"){

        let jBlock = document.getElementsByClassName('j_block');

        if(!jBlock) return;

        for(let i=0;i<jBlock.length;i++){

            let videoId = jBlock[i].getAttribute('data-vid');

            let link = `https://www.le.com/ptv/vplay/${videoId}.html`;

            jBlock[i].firstChild.setAttribute('href',link);
        }
    }

    //B站大会员url处理
    if(nowNode == ".player-container"){
        setTimeout(function(){
            if(!document.querySelector('.player-container')){
                nowNode = '.player-mask';
            }
        },3000)
    }

    // 定时器每1秒检查结点是否存在,不存在则创建
    let timerZhmIcon = setInterval(function(){

        if (document.querySelector('#zhmIcon')){

            clearInterval(timerZhmIcon); //取消定时器

            //let divLength = document.getElementsByTagName('div').length;

            //let zhmPlay=document.getElementsByTagName('div')[divLength-1];

            let zhmPlay = document.getElementById('zhmIcon');

            setTimeout(function(){

                zhmPlay.innerHTML = playWrapHtml;

                if(!isMobile){

                    document.querySelector('.playButton').onmouseover=()=>{

                        document.querySelector(".playLineDiv").style.display='block';

                    }

                    document.querySelector('.playButton').onmouseout=()=>{

                        document.querySelector(".playLineDiv").style.display='none';

                    }
                }

                var playLineTd = document.querySelectorAll('.playLineTd');

                playLineTd.forEach(function(item){

                    item.addEventListener('click',function(){

                        playLineTd.forEach(function(e){

                            e.setAttribute('class','playLineTd zhm_play_video_line_ul_li');
                        })

                        this.setAttribute('class','playLineTd zhm_play_video_line_ul_li zhm_line_selected');

                        playVideoClass.setCookie('playLineAction',this.getAttribute('url'),30);

                        let nowWebNode = document.querySelector(nowNode);

                        if(nowWebNode){

                            nowWebNode.innerHTML = playJxHtml;

                            let playIframe = document.querySelector('#playIframe');

                            playIframe.src= item.getAttribute('url')+couponUrl;

                        }else{
                            console.log('视频网站结点不存在');
                        }

                    })

                })

                document.querySelector('.iconLogo').addEventListener('click',function(){

                    if(isMobile){

                        let playLineDiv = document.querySelector('.zhm_play_video_wrap');

                        let playShow = playLineDiv.style.display;

                        playShow == 'none'? playLineDiv.style.display = 'block':playLineDiv.style.display = 'none';

                    }else{

                        playVideoClass.request('get',`${zhmApiUrl}/jxcode.php?in=${jxCodeInfo.in}&code=${jxCodeInfo.code}`).then((result)=>{

                            location.href=`${zhmApiUrl}/jxjx.php?lrspm=${result}&zhm_jx=${couponUrl}`;

                        }).cath(err=>{})

                    }
                })

            },iconWaitTime)

        }else{

            playVideoClass.createElement('div','zhmIcon');

        }
    },1000)
}

function playMusicFunc(){

    const webUrl = 'http://www.eggvod.cn/newmusic/';

    var musicId = Math.ceil(Math.random()*100000000);

    var musicHtml = "<div href='javascript:void(0)' id="+musicId+" class='zhm_icon' style='cursor:pointer;z-index:98;display:block;width:"+iconVipWidth+"px;position:fixed;"+iconVipPosition+":0;top:"+iconVipTop+"px;text-align:center;'><img src='' title='在音乐单曲播放页面点击图标下载' style='width:"+iconVipWidth+"px'></div>";
    //netease 路由两次,需重定义
    var newUrl = location.href;

    let jxMusicWeb = jxMusic[0].web.filter(function(item){

        return newUrl.match(item.match);

    })

    if(jxMusicWeb.length){

        let timerZhmIcon = setInterval(function(){

            if (document.querySelector('#zhmIcon')){

                clearInterval(timerZhmIcon); // 取消定时器

                let zhmPlay = document.getElementById('zhmIcon');

                setTimeout(function(){

                    zhmPlay.innerHTML = musicHtml;

                    document.querySelector('.zhm_icon').addEventListener('click',function(){

                        switch(jxMusicWeb[0].name){
                            case 'netease':
                                neteaseFun();
                                break;
                            case 'qq':
                                qqFun();
                                break;
                            case 'kugou':
                                kugouFun();
                                break;
                            case 'kuwo':
                                kuwoFun();
                                break;
                            case 'ximalaya':
                                ximalayaFun();
                                break;
                        }

                        function neteaseFun(){

                            let urlParams = playMusicClass.getUrlParams(newUrl);

                            if(urlParams.id == undefined) return;

                            let neteaseUrlEncode = encodeURIComponent('https://music.163.com/song?id='+urlParams.id);

                            let openUrl = webUrl+'?url='+neteaseUrlEncode;

                            window.open(openUrl);

                        }

                        function qqFun(){

                            let qqSongMatch;

                            if(document.querySelector(".player_music__info")){

                                qqSongMatch = document.querySelector(".player_music__info").childNodes[0].href.match(/songDetail\/(\S*)\?/);

                            }else if(document.querySelector("#sim_song_info")){

                                qqSongMatch = document.querySelector("#sim_song_info").childNodes[0].href.match(/song\/(\S*).html/);

                            }else{
                                qqSongMatch = '';
                            }

                            if(!qqSongMatch[1]){console.log('没有获取到歌曲ID'); return};

                            let audioLink = encodeURIComponent(document.querySelector("audio").src);

                            let openUrl = webUrl+'?id='+qqSongMatch[1]+'&type=qq&playUrl='+audioLink;

                            window.open(openUrl);

                        }

                        function kugouFun(){

                            let songKugouMatch = newUrl.match(jxMusicWeb[0].match);

                            let audioSrc = encodeURIComponent(document.querySelector("audio").src);

                            let openUrl = webUrl+'?id='+songKugouMatch[1]+'&type=kugou&playUrl='+audioSrc;

                            window.open(openUrl);
                        }

                        function kuwoFun(){

                            let songKuwoMatch = newUrl.match(jxMusicWeb[0].match);

                            let audioSrc = encodeURIComponent(document.querySelector("audio").src);

                            let openUrl = webUrl+'?id='+songKuwoMatch[1]+'&type=kuwo&playUrl='+audioSrc;

                            window.open(openUrl);
                        }

                        function ximalayaFun(){

                            let urlInfo = newUrl.match(jxMusicWeb[0].match);

                            if(urlInfo[1]){

                                window.open(webUrl+'?id='+urlInfo[1]+'&type=ximalaya&playUrl='+encodeURIComponent(newUrl));

                            }else{

                                console.log('没有获取url参数');
                            }
                        }

                    })

                },iconWaitTime)
            }else{

                playMusicClass.createElement('div','zhmIcon');
            }

        })

    }else{

        console.log('当前音频网址没有添加匹配或匹配错误');

    }

}

function zhNiceFunc(){

    var zhData = [
        {func:'removeVideo',isOpen:GM_getValue('removeVideo','0'),isOnscroll:1,onload:1},
        {func:'removeAD',isOpen:GM_getValue('removeAD','22'),isOnscroll:0,onload:0},
        {func:'downloadVideo',isOpen:GM_getValue('downloadVideo','22'),isOnscroll:0,onload:0},
        {func:'removeRight',isOpen:GM_getValue('removeRight','0'),isOnscroll:0,onload:0},
        {func:'changeLink',isOpen:GM_getValue('changeLink','22'),isOnscroll:0,onload:0},
        {func:'removeKeyword',isOpen:GM_getValue('removeKeyword','0'),isOnscroll:1,onload:1},
    ]

     zhData.forEach(function(item){
         if(item.isOpen==22 && item.onload==0){
             zhClass[item.func]();
         }
     })

    window.onload=function(){
        zhData.forEach(function(item){
            if(item.isOpen==22 && item.onload==1){
                zhClass[item.func]();
            }
        })
    }
    window.onscroll = function(){

        var scrollTop = document.documentElement.scrollTop;

        if(scrollTop > 200){

            zhData.forEach(function(item){
                if(item.isOpen==22 && item.isOnscroll==1){

                    zhClass[item.func]();
                }
            })

        }

    }

}

function baiduFunc(){
    let pt = '', selectList = [], params = {}, mode = '', width = 800, pan = {}, color = '',
    doc = $(document), progress = {}, request = {}, ins = {}, idm = {};
    const version = parseFloat(pan.version);
    const author = 'YouXiaoHou';
    const name = '网盘直链下载助手';
    const customClass = {
        popup: 'pl-popup',
        header: 'pl-header',
        title: 'pl-title',
        closeButton: 'pl-close',
        content: 'pl-content',
        input: 'pl-input',
        footer: 'pl-footer'
    };

    const terminalType = {
        wc: "Windows CMD",
        wp: "Windows PowerShell",
        lt: "Linux 终端",
        ls: "Linux Shell",
        mt: "MacOS 终端",
    };

    let toast = Swal.mixin({
        toast: true,
        position: 'top',
        showConfirmButton: false,
        timer: 3500,
        timerProgressBar: false,
        didOpen: (toast) => {
            toast.addEventListener('mouseenter', Swal.stopTimer);
            toast.addEventListener('mouseleave', Swal.resumeTimer);
        }
    });

    const message = {
        success: (text) => {
            toast.fire({title: text, icon: 'success'});
        },
        error: (text) => {
            toast.fire({title: text, icon: 'error'});
        },
        warning: (text) => {
            toast.fire({title: text, icon: 'warning'});
        },
        info: (text) => {
            toast.fire({title: text, icon: 'info'});
        },
        question: (text) => {
            toast.fire({title: text, icon: 'question'});
        }
    };

    let base = {
        clog(c) {
            console.group(`[${name}]`);
            console.log(c);
            console.groupEnd();
        },
        getCookie(name) {
            let arr = document.cookie.replace(/\s/g, "").split(';');
            for (let i = 0, l = arr.length; i < l; i++) {
                let tempArr = arr[i].split('=');
                if (tempArr[0] == name) {
                    return decodeURIComponent(tempArr[1]);
                }
            }
            return '';
        },
        getValue(name) {
            return GM_getValue(name);
        },
        setValue(name, value) {
            GM_setValue(name, value);
        },
        getStorage(key) {
            return localStorage.getItem(key);
        },
        setStorage(key, value) {
            return localStorage.setItem(key, value);
        },
        setClipboard(text) {
            GM_setClipboard(text, 'text');
        },
        e(str) {
            return btoa(unescape(encodeURIComponent(str)));
        },
        d(str) {
            return decodeURIComponent(escape(atob(str)));
        },

        getExtension(name) {
            const reg = /(?!\.)\w+$/;
            if (reg.test(name)) {
                let match = name.match(reg);
                return match[0].toUpperCase();
            }
            return '';
        },
        sizeFormat(value) {
            if (value === +value) {
                let unit = ["B", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
                let index = Math.floor(Math.log(value) / Math.log(1024));
                let size = value / Math.pow(1024, index);
                size = size.toFixed(1);
                return size + unit[index];
            }
            return '';
        },
        sortByName(arr) {
            const handle = () => {
                return  (a, b) => {
                    const p1 = a.filename ? a.filename : a.server_filename;
                    const p2 = b.filename ? b.filename : b.server_filename;
                    return p1.localeCompare(p2, "zh-CN");
                };
            };
            arr.sort(handle());
        },

        blobDownload(blob, filename) {
            if (blob instanceof Blob) {
                const url = URL.createObjectURL(blob);
                const a = document.createElement('a');
                a.href = url;
                a.download = filename;
                a.click();
                URL.revokeObjectURL(url);
            }
        },

        post(url, data, headers, type) {
            if (Object.prototype.toString.call(data) === '[object Object]') {
                data = JSON.stringify(data);
            }
            return new Promise((resolve, reject) => {
                GM_xmlhttpRequest({
                    method: "POST", url, headers, data,
                    responseType: type || 'json',
                    onload: (res) => {
                        type === 'blob' ? resolve(res) : resolve(res.response || res.responseText);
                    },
                    onerror: (err) => {
                        reject(err);
                    },
                });
            });
        },
        get(url, headers, type, extra) {
            return new Promise((resolve, reject) => {
                let requestObj = GM_xmlhttpRequest({
                    method: "GET", url, headers,
                    responseType: type || 'json',
                    onload: (res) => {
                        if (res.status === 204) {
                            requestObj.abort();
                            idm[extra.index] = true;
                        }
                        if (type === 'blob') {
                            res.status === 200 && base.blobDownload(res.response, extra.filename);
                            resolve(res);
                        } else {
                            resolve(res.response || res.responseText);
                        }
                    },
                    onprogress: (res) => {
                        if (extra && extra.filename && extra.index) {
                            res.total > 0 ? progress[extra.index] = (res.loaded * 100 / res.total).toFixed(2) : progress[extra.index] = 0.00;
                        }
                    },
                    onloadstart() {
                        extra && extra.filename && extra.index && (request[extra.index] = requestObj);
                    },
                    onerror: (err) => {
                        reject(err);
                    },
                });
            });
        },
        addStyle(id, tag, css) {
            tag = tag || 'style';
            let doc = document, styleDom = doc.getElementById(id);
            if (styleDom) return;
            let style = doc.createElement(tag);
            style.rel = 'stylesheet';
            style.id = id;
            tag === 'style' ? style.innerHTML = css : style.href = css;
            doc.getElementsByTagName('head')[0].appendChild(style);
        },

        initDefaultConfig() {
            let value = [{
                name: 'setting_rpc_domain',
                value: 'http://localhost'
            }, {
                name: 'setting_rpc_port',
                value: '16800'
            }, {
                name: 'setting_rpc_path',
                value: '/jsonrpc'
            }, {
                name: 'setting_rpc_token',
                value: ''
            }, {
                name: 'setting_rpc_dir',
                value: 'D:'
            }, {
                name: 'setting_terminal_type',
                value: 'wc'
            }, {
                name: 'setting_theme_color',
                value: '#09AAFF'
            }, {
                name: 'setting_init_code',
                value: ''
            }];

            value.forEach((v) => {
                base.getValue(v.name) === undefined && base.setValue(v.name, v.value);
            });
        },

        showSetting() {
            let dom = '', btn = '',
                colorList = ['#09AAFF', '#cc3235', '#526efa', '#518c17', '#ed944b', '#f969a5', '#bca280'];
            dom += `<label class="pl-setting-label"><div class="pl-label">RPC主机</div><input type="text"  placeholder="主机地址,需带上http(s)://" class="pl-input listener-domain" value="${base.getValue('setting_rpc_domain')}"></label>`;
            dom += `<label class="pl-setting-label"><div class="pl-label">RPC端口</div><input type="text" placeholder="端口号,例如:Motrix为16800" class="pl-input listener-port" value="${base.getValue('setting_rpc_port')}"></label>`;
            dom += `<label class="pl-setting-label"><div class="pl-label">RPC路径</div><input type="text" placeholder="路径,默认为/jsonrpc" class="pl-input listener-path" value="${base.getValue('setting_rpc_path')}"></label>`;
            dom += `<label class="pl-setting-label"><div class="pl-label">RPC密钥</div><input type="text" placeholder="无密钥无需填写" class="pl-input listener-token" value="${base.getValue('setting_rpc_token')}"></label>`;
            dom += `<label class="pl-setting-label"><div class="pl-label">保存路径</div><input type="text" placeholder="文件下载后保存路径,例如:D:" class="pl-input listener-dir" value="${base.getValue('setting_rpc_dir')}"></label>`;

            colorList.forEach((v) => {
                btn += `<div data-color="${v}" style="background: ${v};border: 1px solid ${v}" class="pl-color-box listener-color ${v === base.getValue('setting_theme_color') ? 'checked' : ''}"></div>`;
            });
            dom += `<label class="pl-setting-label"><div class="pl-label">终端类型</div><select class="pl-input listener-terminal">`;
            Object.keys(terminalType).forEach(k => {
                dom += `<option value="${k}" ${base.getValue('setting_terminal_type') === k ? 'selected' : ''}>${terminalType[k]}</option>`;
            });
            dom += `</select></label>`;
            dom += `<label class="pl-setting-label"><div class="pl-label">主题颜色</div> <div class="pl-color">${btn}<div></label>`;
            dom = '<div>' + dom + '</div>';

            Swal.fire({
                title: '助手配置',
                html: dom,
                icon: 'info',
                showCloseButton: true,
                showConfirmButton: false,
                footer: pan.footer,
            }).then(() => {
                message.success('设置成功!');
                history.go(0);
            });

            doc.on('click', '.listener-color', async (e) => {
                base.setValue('setting_theme_color', e.target.dataset.color);
                message.success('设置成功!');
                history.go(0);
            });
            doc.on('input', '.listener-domain', async (e) => {
                base.setValue('setting_rpc_domain', e.target.value);
            });
            doc.on('input', '.listener-port', async (e) => {
                base.setValue('setting_rpc_port', e.target.value);
            });
            doc.on('input', '.listener-path', async (e) => {
                base.setValue('setting_rpc_path', e.target.value);
            });
            doc.on('input', '.listener-token', async (e) => {
                base.setValue('setting_rpc_token', e.target.value);
            });
            doc.on('input', '.listener-dir', async (e) => {
                base.setValue('setting_rpc_dir', e.target.value);
            });
            doc.on('change', '.listener-terminal', async (e) => {
                base.setValue('setting_terminal_type', e.target.value);
            });
        },

        registerMenuCommand() {
            GM_registerMenuCommand('⚙️ 网盘设置', () => {
                this.showSetting();
            });
        },

        createTip() {
            $('body').append('<div class="pl-tooltip"></div>');

            doc.on('mouseenter mouseleave', '.listener-tip', (e) => {
                if (e.type === 'mouseenter') {
                    let filename = e.currentTarget.innerText;
                    let size = e.currentTarget.dataset.size;
                    let tip = `${filename}<span style="margin-left: 10px;color: #f56c6c;">${size}</span>`;
                    $(e.currentTarget).css({opacity: '0.5'});
                    $('.pl-tooltip').html(tip).css({
                        'left': e.pageX + 10 + 'px',
                        'top': e.pageY - e.currentTarget.offsetTop > 14 ? e.pageY + 'px' : e.pageY + 20 + 'px'
                    }).show();
                } else {
                    $(e.currentTarget).css({opacity: '1'});
                    $('.pl-tooltip').hide(0);
                }
            });
        },

        createLoading() {
            return $('<div class="pl-loading"><div class="pl-loading-box"><div><div></div><div></div></div></div></div>');
        },

        createDownloadIframe() {
            let $div = $('<div style="padding:0;margin:0;display:block"></div>');
            let $iframe = $('<iframe src="javascript:;" id="downloadIframe" style="display:none"></iframe>');
            $div.append($iframe);
            $('body').append($div);
        },

        addPanLinkerStyle() {
            color = base.getValue('setting_theme_color');
            let css = `
        body::-webkit-scrollbar { display: none }
        ::-webkit-scrollbar { width: 6px; height: 10px }
        ::-webkit-scrollbar-track { border-radius: 0; background: none }
        ::-webkit-scrollbar-thumb { background-color: rgba(85,85,85,.4) }
        ::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover { border-radius: 5px; -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.2) }
        ::-webkit-scrollbar-thumb:hover { background-color: rgba(85,85,85,.3) }
        .swal2-popup { font-size: 16px !important; }
        .pl-popup { font-size: 12px !important; }
        .pl-popup a { color: ${color} !important; }
        .pl-header { padding: 0!important;align-items: flex-start!important; border-bottom: 1px solid #eee!important; margin: 0 0 10px!important; padding: 0 0 5px!important; }
        .pl-title { font-size: 16px!important; line-height: 1!important;white-space: nowrap!important; text-overflow: ellipsis!important;}
        .pl-content { padding: 0 !important; font-size: 12px!important; }
        .pl-main { max-height: 400px;overflow-y:scroll; }
        .pl-footer {font-size: 12px!important;justify-content: flex-start!important; margin: 10px 0 0!important; padding: 5px 0 0!important; color: #f56c6c!important; }
        .pl-item { display: flex; align-items: center; line-height: 22px; }
        .pl-item-name { flex: 0 0 150px; text-align: left;margin-right: 10px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; cursor:default; }
        .pl-item-link { flex: 1; overflow: hidden; text-align: left; white-space: nowrap; text-overflow: ellipsis;cursor:pointer }
        .pl-item-btn { background: ${color}; padding: 4px 5px; border-radius: 3px; line-height: 1; cursor: pointer; color: #fff; }
        .pl-item-tip { display: flex; justify-content: space-between;flex: 1; }
        .pl-back { width: 70px; background: #ddd; border-radius: 3px; cursor:pointer; margin:1px 0; }
        .pl-ext { display: inline-block; width: 44px; background: #999; color: #fff; height: 16px; line-height: 16px; font-size: 12px; border-radius: 3px;}
        .pl-retry {padding: 3px 10px; background: #cc3235; color: #fff; border-radius: 3px; cursor: pointer;}
        .pl-browserdownload { padding: 3px 10px; background: ${color}; color: #fff; border-radius: 3px; cursor: pointer;}
        .pl-item-progress { display:flex;flex: 1;align-items:center}
        .pl-progress { display: inline-block;vertical-align: middle;width: 100%; box-sizing: border-box;line-height: 1;position: relative;height:15px; flex: 1}
        .pl-progress-outer { height: 15px;border-radius: 100px;background-color: #ebeef5;overflow: hidden;position: relative;vertical-align: middle;}
        .pl-progress-inner{ position: absolute;left: 0;top: 0;background-color: #409eff;text-align: right;border-radius: 100px;line-height: 1;white-space: nowrap;transition: width .6s ease;}
        .pl-progress-inner-text { display: inline-block;vertical-align: middle;color: #d1d1d1;font-size: 12px;margin: 0 5px;height: 15px}
        .pl-progress-tip{ flex:1;text-align:right}
        .pl-progress-how{ flex: 0 0 90px; background: #ddd; border-radius: 3px; margin-left: 10px; cursor: pointer; text-align: center;}
        .pl-progress-stop{ flex: 0 0 50px; padding: 0 10px; background: #cc3235; color: #fff; border-radius: 3px; cursor: pointer;margin-left:10px;height:20px}
        .pl-progress-inner-text:after { display: inline-block;content: "";height: 100%;vertical-align: middle;}
        .pl-btn-primary { background: ${color}; border: 0; border-radius: 4px; color: #ffffff; cursor: pointer; font-size: 12px; outline: none; display:flex; align-items: center; justify-content: center; margin: 2px 0; padding: 6px 0;transition: 0.3s opacity; }
        .pl-btn-primary:hover { opacity: 0.9;transition: 0.3s opacity; }
        .pl-btn-success { background: #55af28; animation: easeOpacity 1.2s 2; animation-fill-mode:forwards }
        .pl-btn-info { background: #606266; }
        .pl-btn-warning { background: #da9328; }
        .pl-btn-warning { background: #da9328; }
        .pl-btn-danger { background: #cc3235; }
        .pl-dropdown-menu {position: absolute;right: 0;top: 34px;padding: 5px 0;color: rgb(37, 38, 43);background: #fff;z-index: 999;width: 102px;border: 1px solid #ddd;border-radius: 10px; box-shadow: 0 0 1px 1px rgb(28 28 32 / 5%), 0 8px 24px rgb(28 28 32 / 12%);}
        .pl-dropdown-menu-item { height: 30px;display: flex;align-items: center;justify-content: center; }
        .pl-dropdown-menu-item:hover { background-color: rgba(132,133,141,0.08);}
        .pl-button-init { opacity: 0.5; animation: easeInitOpacity 1.2s 3; animation-fill-mode:forwards }
         @keyframes easeInitOpacity { from { opacity: 0.5; } 50% { opacity: 1 } to { opacity: 0.5; } }
         @keyframes easeOpacity { from { opacity: 1; } 50% { opacity: 0.35 } to { opacity: 1; } }
        .element-clicked { opacity: 0.5; }
        .pl-extra { margin-top: 10px;display:flex}
        .pl-extra button { flex: 1}
        .pointer { cursor:pointer }
        .pl-setting-label { display: flex;align-items: center;justify-content: space-between;padding-top: 10px; }
        .pl-label { flex: 0 0 100px;text-align:left; }
        .pl-input { flex: 1; padding: 8px 10px; border: 1px solid #c2c2c2; border-radius: 5px; font-size: 14px }
        .pl-color { flex: 1;display: flex;flex-wrap: wrap; margin-right: -10px;}
        .pl-color-box { width: 35px;height: 35px;margin:10px 10px 0 0;; box-sizing: border-box;border:1px solid #fff;cursor:pointer }
        .pl-color-box.checked { border:3px dashed #111!important }
        .pl-close:focus { outline: 0; box-shadow: none; }
        .tag-danger {color:#cc3235;margin: 0 5px;}
        .pl-tooltip { position: absolute; color: #ffffff; max-width: 600px; font-size: 12px; padding: 5px 10px; background: #333; border-radius: 5px; z-index: 110000; line-height: 1.3; display:none; word-break: break-all;}
         @keyframes load { 0% { transform: rotate(0deg) } 100% { transform: rotate(360deg) } }
        .pl-loading-box > div > div {position: absolute;border-radius: 50%;}
        .pl-loading-box > div > div:nth-child(1) {top: 9px;left: 9px;width: 82px;height: 82px;background: #ffffff;}
        .pl-loading-box > div > div:nth-child(2) {top: 14px;left: 38px;width: 25px;height: 25px;background: #666666;animation: load 1s linear infinite;transform-origin: 12px 36px;}
        .pl-loading {width: 16px;height: 16px;display: inline-block;overflow: hidden;background: none;}
        .pl-loading-box {width: 100%;height: 100%;position: relative;transform: translateZ(0) scale(0.16);backface-visibility: hidden;transform-origin: 0 0;}
        .pl-loading-box div { box-sizing: content-box; }
        .swal2-container { z-index:100000!important; }
        body.swal2-height-auto { height: inherit!important; }
        `;
            this.addStyle('panlinker-style', 'style', css);
        },

        async initDialog() {
            let result = await Swal.fire({
                title: "请支持原创",
                html: `<div><img style="width: 250px;margin-bottom: 10px;" src="${pan.img}" alt="${pan.img}"><input class="swal2-input" id="init" type="text" placeholder="请随便输入暗号"></div>`,
                allowOutsideClick: false,
                showCloseButton: true,
                confirmButtonText: '确定'
            });
            if (result.isDismissed && result.dismiss === 'close') return;
            if (pan.num == pan.num) {
                base.setValue('setting_init_code', pan.num);
                message.success("暗号正确");
                setTimeout(() => {
                    history.go(0);
                }, 1500);
            } else {
                await Swal.fire({
                    title:"暗号不正确",
                    text: "暗号不正确",
                    confirmButtonText: '重新输入',
                    imageUrl: pan.img,
                });
                await this.initDialog();
            }
        },
    };

    let baidu = {

        _getExtra() {
            let seKey = decodeURIComponent(base.getCookie('BDCLND'));
            return '{' + '"sekey":"' + seKey + '"' + "}";
        },

        _getSurl() {
            let reg = /(?<=s\/|surl=)([a-zA-Z0-9_-]+)/g;
            if (reg.test(location.href)) {
                return location.href.match(reg)[0];
            }
            return '';
        },

        _getFidList() {
            let fidlist = [];
            selectList.forEach(v => {
                if (+v.isdir === 1) return;
                fidlist.push(v.fs_id);
            });
            return '[' + fidlist + ']';
        },

        _resetData() {
            progress = {};
            $.each(request, (key) => {
                (request[key]).abort();
            });
            $.each(ins, (key) => {
                clearInterval(ins[key]);
            });
            idm = {};
            ins = {};
            request = {};
        },

        setBDUSS() {
            try {
                GM_cookie && GM_cookie('list', {name: 'BDUSS'}, (cookies, error) => {
                    if (!error) {
                        base.setStorage("baiduyunPlugin_BDUSS", JSON.stringify({BDUSS: cookies[0].value}));
                    }
                });
            } catch (e) {
            }
        },

        getBDUSS() {
            let baiduyunPlugin_BDUSS = base.getStorage('baiduyunPlugin_BDUSS') ? base.getStorage('baiduyunPlugin_BDUSS') : '{"baiduyunPlugin_BDUSS":""}';
            return JSON.parse(baiduyunPlugin_BDUSS).BDUSS || '';
        },

        convertLinkToAria(link, filename, ua) {
            let BDUSS = this.getBDUSS();
            if (!!BDUSS) {
                filename = filename.replace(' ', '_');
                return encodeURIComponent(`aria2c "${link}" --out "${filename}" --header "User-Agent: ${ua}" --header "Cookie: BDUSS=${BDUSS}"`);
            }
            return {
                link: pan.assistant,
                text: pan.init[5]
            };
        },

        convertLinkToCurl(link, filename, ua) {
            let BDUSS = this.getBDUSS();
            if (!!BDUSS) {
                let terminal = base.getValue('setting_terminal_type');
                filename = filename.replace(' ', '_');
                return encodeURIComponent(`${terminal !== 'wp' ? 'curl' : 'curl.exe'} -L "${link}" --output "${filename}" -A "${ua}" -b "BDUSS=${BDUSS}"`);
            }
            return {
                link: pan.assistant,
                text: pan.init[5]
            };
        },

        addPageListener() {
            function _factory(e) {
                let target = $(e.target);
                let item = target.parents('.pl-item');
                let link = item.find('.pl-item-link');
                let progress = item.find('.pl-item-progress');
                let tip = item.find('.pl-item-tip');
                return {
                    item, link, progress, tip, target,
                };
            }

            function _reset(i) {
                ins[i] && clearInterval(ins[i]);
                request[i] && request[i].abort();
                progress[i] = 0;
                idm[i] = false;
            }

            doc.on('mouseenter mouseleave click', '.pl-button', (e) => {
                if (e.type === 'mouseleave') {
                    $(e.currentTarget).removeClass('button-open');
                } else {
                    $(e.currentTarget).addClass('button-open');
                    $(e.currentTarget).find('.pl-menu').show();
                }
            });
            doc.on('mouseleave', '.pl-menu', (e) => {
                $(e.currentTarget).hide();
            });
            doc.on('click', '.pl-button-mode', (e) => {
                mode = e.target.dataset.mode;
                Swal.showLoading();
                this.getPCSLink();
            });
            doc.on('click', '.listener-link-api', async (e) => {
                e.preventDefault();
                let o = _factory(e);
                let $width = o.item.find('.pl-progress-inner');
                let $text = o.item.find('.pl-progress-inner-text');
                let filename = o.link[0].dataset.filename;
                let index = o.link[0].dataset.index;
                _reset(index);
                base.get(o.link[0].dataset.link, {"User-Agent": pan.ua}, 'blob', {filename, index});
                ins[index] = setInterval(() => {
                    let prog = +progress[index] || 0;
                    let isIDM = idm[index] || false;
                    if (isIDM) {
                        o.tip.hide();
                        o.progress.hide();
                        o.link.text('已成功唤起IDM,请查看IDM下载框!').animate({opacity: '0.5'}, "slow").show();
                        clearInterval(ins[index]);
                        idm[index] = false;
                    } else {
                        o.link.hide();
                        o.tip.hide();
                        o.progress.show();
                        $width.css('width', prog + '%');
                        $text.text(prog + '%');
                        if (prog == 100) {
                            clearInterval(ins[index]);
                            progress[index] = 0;
                            o.item.find('.pl-progress-stop').hide();
                            o.item.find('.pl-progress-tip').html('下载完成,正在弹出浏览器下载框!');
                        }
                    }
                }, 500);
            });
            doc.on('click', '.listener-retry', async (e) => {
                let o = _factory(e);
                o.tip.hide();
                o.link.show();
            });
            doc.on('click', '.listener-how', async (e) => {
                let o = _factory(e);
                let index = o.link[0].dataset.index;
                if (request[index]) {
                    request[index].abort();
                    clearInterval(ins[index]);
                    o.progress.hide();
                    o.tip.show();
                }

            });
            doc.on('click', '.listener-stop', async (e) => {
                let o = _factory(e);
                let index = o.link[0].dataset.index;
                if (request[index]) {
                    request[index].abort();
                    clearInterval(ins[index]);
                    o.tip.hide();
                    o.progress.hide();
                    o.link.show(0);
                }
            });
            doc.on('click', '.listener-back', async (e) => {
                let o = _factory(e);
                o.tip.hide();
                o.link.show();
            });
            doc.on('click', '.listener-link-aria, .listener-copy-all', (e) => {
                e.preventDefault();
                if (!e.target.dataset.link) {
                    $(e.target).removeClass('listener-copy-all').addClass('pl-btn-danger').html(`${pan.init[5]}👉<a href="${pan.assistant}" target="_blank" class="pl-a">点击此处安装</a>👈`);
                } else {
                    base.setClipboard(decodeURIComponent(e.target.dataset.link));
                    $(e.target).text('复制成功,快去粘贴吧!').animate({opacity: '0.5'}, "slow");
                }
            });
            doc.on('click', '.listener-link-rpc', async (e) => {
                let target = $(e.currentTarget);
                target.find('.icon').remove();
                target.find('.pl-loading').remove();
                target.prepend(base.createLoading());
                let res = await this.sendLinkToRPC(e.currentTarget.dataset.filename, e.currentTarget.dataset.link);
                if (res === 'success') {
                    $('.listener-rpc-task').show();
                    target.removeClass('pl-btn-danger').html('发送成功,快去看看吧!').animate({opacity: '0.5'}, "slow");
                } else if (res === 'assistant') {
                    target.addClass('pl-btn-danger').html(`${pan.init[5]}👉<a href="${pan.assistant}" target="_blank" class="pl-a">点击此处安装</a>👈`);
                } else {
                    target.addClass('pl-btn-danger').text('发送失败,请检查您的RPC配置信息!').animate({opacity: '0.5'}, "slow");
                }
            });
            doc.on('click', '.listener-send-rpc', (e) => {
                $('.listener-link-rpc').click();
                $(e.target).text('发送完成,发送结果见上方按钮!').animate({opacity: '0.5'}, "slow");
            });
            doc.on('click', '.listener-open-setting', () => {
                base.showSetting();
            });
            doc.on('click', '.listener-rpc-task', () => {
                let rpc = JSON.stringify({
                    domain: base.getValue('setting_rpc_domain'),
                    port: base.getValue('setting_rpc_port'),
                }), url = `${pan.d}/?rpc=${base.e(rpc)}#${base.getValue('setting_rpc_token')}`;
                GM_openInTab(url, {active: true});
            });
            document.documentElement.addEventListener('mouseup', (e) => {
                if (e.target.nodeName === 'A' && ~e.target.className.indexOf('pl-a')) {
                    e.stopPropagation();
                }
            }, true);
        },

        addButton() {
            if (!pt) return;
            let $toolWrap;
            let $button = $(`<div class="g-dropdown-button pointer pl-button"><div style="color:#fff;background: ${color};border-color:${color}" class="g-button g-button-blue"><span class="g-button-right"><em class="icon icon-download"></em><span class="text" style="width: 60px;">下载助手</span></span></div><div class="menu" style="width:auto;z-index:41;border-color:${color}"><div style="color:${color}" class="g-button-menu pl-button-mode" data-mode="api">API下载</div><div style="color:${color}" class="g-button-menu pl-button-mode" data-mode="aria">Aria下载</div><div style="color:${color}" class="g-button-menu pl-button-mode" data-mode="rpc">RPC下载</div><div style="color:${color}" class="g-button-menu pl-button-mode" data-mode="curl">cURL下载</div></div></div>`);
            if (pt === 'home') $toolWrap = $(pan.btn.home);
            if (pt === 'main') {
                $toolWrap = $(pan.btn.main);
                $button = $(`<div class="pl-button" style="position: relative; display: inline-block; margin-right: 8px;"><button class="u-button u-button--primary u-button--small is-round is-has-icon" style="background: ${color};border-color: ${color};font-size: 14px; padding: 8px 16px; border: none;"><i class="u-icon u-icon-download"></i><span>下载助手</span></button><ul class="dropdown-list nd-common-float-menu pl-menu" style="display: none;"><li class="sub cursor-p pl-button-mode" data-mode="api">API下载</li><li class="sub cursor-p pl-button-mode" data-mode="aria">Aria下载</li><li class="sub cursor-p pl-button-mode" data-mode="rpc">RPC下载</li><li class="sub cursor-p pl-button-mode" data-mode="curl">cURL下载</li></ul></div>`);
            }
            if (pt === 'share') $toolWrap = $(pan.btn.share);
            $toolWrap.prepend($button);
            base.clog(`助手加载成功!版本:${version}`);
            this.setBDUSS();
            this.addPageListener();
        },

        addInitButton() {
            if (!pt) return;
            let $toolWrap;
            let $button = $(`<div class="g-dropdown-button pointer pl-button-init" style="opacity:.5"><div style="color:#fff;background: ${color};border-color:${color}" class="g-button g-button-blue"><span class="g-button-right"><em class="icon icon-download"></em><span class="text" style="width: 60px;">下载助手</span></span></div></div>`);
            if (pt === 'home') $toolWrap = $(pan.btn.home);
            if (pt === 'main') {
                $toolWrap = $(pan.btn.main);
                $button = $(`<div class="pl-button-init" style="opacity:.5; display: inline-block; margin-right: 8px;"><button class="u-button u-button--primary u-button--small is-round is-has-icon" style="background: ${color};border-color: ${color};font-size: 14px; padding: 8px 16px; border: none;"><i class="u-icon u-icon-download"></i><span>下载助手</span></button></div>`);
            }
            if (pt === 'share') $toolWrap = $(pan.btn.share);
            $toolWrap.prepend($button);
            $button.click(() => base.initDialog());
        },

        async getPCSLink() {
            selectList = this.getSelectedList();
            let fidList = this._getFidList(), url, res;

            if (pt === 'home' || pt === 'main') {
                if (selectList.length === 0) {
                    return message.error('提示:请先勾选要下载的文件!');
                }
                if (fidList.length === 2) {
                    return message.error('提示:请打开文件夹后勾选文件!');
                }
                fidList = encodeURIComponent(fidList);
                url = `${pan.pcs[0]}&fsids=${fidList}`;
                res = await base.get(url, {"User-Agent": pan.ua});
            }
            if (pt === 'share') {
                this.getShareData();
                if (selectList.length === 0) {
                    return message.error('提示:请先勾选要下载的文件!');
                }
                if (fidList.length === 2) {
                    return message.error('提示:请打开文件夹后勾选文件!');
                }
                if (!params.sign) {
                    let url = `${pan.pcs[2]}&surl=${params.surl}&logid=${params.logid}`;
                    let r = await base.get(url);
                    if (r.errno === 0) {
                        params.sign = r.data.sign;
                        params.timestamp = r.data.timestamp;
                    } else {
                        let dialog = await Swal.fire({
                            toast: true,
                            icon: 'info',
                            title: `提示:请将文件<span class="tag-danger">[保存到网盘]</span>👉在<span class="tag-danger">[我的网盘]</span>中下载!`,
                            showConfirmButton: true,
                            confirmButtonText: '点击保存',
                            position: 'top',
                        });
                        if (dialog.isConfirmed) {
                            $('.tools-share-save-hb')[0].click();
                        }
                        return;
                    }
                }
                if (!params.bdstoken) {
                    return message.error('提示:请先登录网盘!');
                }
                let formData = new FormData();
                formData.append('encrypt', params.encrypt);
                formData.append('product', params.product);
                formData.append('uk', params.uk);
                formData.append('primaryid', params.primaryid);
                formData.append('fid_list', fidList);
                formData.append('logid', params.logid);
                params.shareType === 'secret' ? formData.append('extra', params.extra) : '';
                url = `${pan.pcs[1]}&sign=${params.sign}&timestamp=${params.timestamp}`;
                res = await base.post(url, formData, {"User-Agent": pan.ua});
            }
            if (res.errno === 0) {
                let html = this.generateDom(res.list);
                this.showMainDialog(pan[mode][0], html, pan[mode][1]);
            } else if (res.errno === 112) {
                return message.error('提示:页面过期,请刷新重试!');
            } else {
                message.error('提示:获取下载链接失败!请刷新网页后重试!');
            }
        },

        generateDom(list) {
            let content = '<div class="pl-main">';
            let alinkAllText = '';
            base.sortByName(list);
            list.forEach((v, i) => {
                if (v.isdir === 1) return;
                let filename = v.server_filename || v.filename;
                let ext = base.getExtension(filename);
                let size = base.sizeFormat(v.size);
                let dlink = v.dlink;
                if (mode === 'api') {
                    content += `<div class="pl-item">
                            <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                            <a class="pl-item-link pl-a listener-link-api" href="${dlink}" data-filename="${filename}" data-link="${dlink}" data-index="${i}">${dlink}</a>
                            <div class="pl-item-tip" style="display: none"><span>若没有弹出IDM下载框,找到IDM <b>选项</b> -> <b>文件类型</b> -> <b>第一个框</b> 中添加后缀 <span class="pl-ext">${ext}</span>,<a href="${pan.idm}" target="_blank" class="pl-a">详见此处</a></span> <span class="pl-back listener-back">返回</span></div>
                            <div class="pl-item-progress" style="display: none">
                                <div class="pl-progress">
                                    <div class="pl-progress-outer"></div>
                                    <div class="pl-progress-inner" style="width:5%">
                                      <div class="pl-progress-inner-text">0%</div>
                                    </div>
                                </div>
                                <span class="pl-progress-stop listener-stop">取消下载</span>
                                <span class="pl-progress-tip">未发现IDM,使用自带浏览器下载</span>
                                <span class="pl-progress-how listener-how">如何唤起IDM?</span>
                            </div></div>`;
                }
                if (mode === 'aria') {
                    let alink = this.convertLinkToAria(dlink, filename, pan.ua);
                    if (typeof (alink) === 'object') {
                        content += `<div class="pl-item">
                            <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                            <a class="pl-item-link pl-a" target="_blank" href="${alink.link}" title="点击复制aria2c链接" data-filename="${filename}" data-link="${alink.link}">${decodeURIComponent(alink.text)}</a> </div>`;
                    } else {
                        alinkAllText += alink + '\r\n';
                        content += `<div class="pl-item">
                            <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                            <a class="pl-item-link pl-a listener-link-aria" href="${alink}" title="点击复制aria2c链接" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> </div>`;
                    }
                }
                if (mode === 'rpc') {
                    content += `<div class="pl-item">
                            <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                            <button class="pl-item-link listener-link-rpc pl-btn-primary pl-btn-info" data-filename="${filename}" data-link="${dlink}"><em class="icon icon-device"></em><span style="margin-left: 5px;">推送到 RPC 下载器</span></button></div>`;
                }
                if (mode === 'curl') {
                    let alink = this.convertLinkToCurl(dlink, filename, pan.ua);
                    if (typeof (alink) === 'object') {
                        content += `<div class="pl-item">
                            <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                            <a class="pl-item-link pl-a" target="_blank" href="${alink.link}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink.link}">${decodeURIComponent(alink.text)}</a> </div>`;
                    } else {
                        alinkAllText += alink + '\r\n';
                        content += `<div class="pl-item">
                            <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                            <a class="pl-item-link pl-a listener-link-aria" href="${alink}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> </div>`;
                    }
                }
            });
            content += '</div>';
            if (mode === 'aria')
                content += `<div class="pl-extra"><button class="pl-btn-primary listener-copy-all" data-link="${alinkAllText}">复制全部链接</button></div>`;
            if (mode === 'rpc') {
                let rpc = base.getValue('setting_rpc_domain') + ':' + base.getValue('setting_rpc_port') + base.getValue('setting_rpc_path');
                content += `<div class="pl-extra"><button class="pl-btn-primary listener-send-rpc">发送全部链接</button><button title="${rpc}" class="pl-btn-primary pl-btn-warning listener-open-setting" style="margin-left: 10px">设置 RPC 参数(当前为:${rpc})</button><button class="pl-btn-primary pl-btn-success listener-rpc-task" style="margin-left: 10px;display: none">查看下载任务</button></div>`;
            }
            if (mode === 'curl')
                content += `<div class="pl-extra"><button class="pl-btn-primary listener-copy-all" data-link="${alinkAllText}">复制全部链接</button><button class="pl-btn-primary pl-btn-warning listener-open-setting" style="margin-left: 10px;">设置终端类型(当前为:${terminalType[base.getValue('setting_terminal_type')]})</button></div>`;
            return content;
        },

        async sendLinkToRPC(filename, link) {
            let rpc = {
                domain: base.getValue('setting_rpc_domain'),
                port: base.getValue('setting_rpc_port'),
                path: base.getValue('setting_rpc_path'),
                token: base.getValue('setting_rpc_token'),
                dir: base.getValue('setting_rpc_dir'),
            };
            let BDUSS = this.getBDUSS();
            if (!BDUSS) return 'assistant';

            let url = `${rpc.domain}:${rpc.port}${rpc.path}`;
            let rpcData = {
                id: new Date().getTime(),
                jsonrpc: '2.0',
                method: 'aria2.addUri',
                params: [`token:${rpc.token}`, [link], {
                    dir: rpc.dir,
                    out: filename,
                    header: [`User-Agent: ${pan.ua}`, `Cookie: BDUSS=${BDUSS}`]
                }]
            };
            try {
                let res = await base.post(url, rpcData, {"User-Agent": pan.ua}, '');
                if (res.result) return 'success';
                return 'fail';
            } catch (e) {
                return 'fail';
            }
        },

        getSelectedList() {
            try {
                return require('system-core:context/context.js').instanceForSystem.list.getSelected();
            } catch (e) {
                return document.querySelector('.nd-main-list').__vue__.selectedList;
            }
        },

        getLogid() {
            let ut = require("system-core:context/context.js").instanceForSystem.tools.baseService;
            return ut.base64Encode(base.getCookie("BAIDUID"));
        },

        getShareData() {
            let res = locals.dump();
            params.shareType = 'secret';
            params.sign = '';
            params.timestamp = '';
            params.bdstoken = res.bdstoken.value;
            params.channel = 'chunlei';
            params.clienttype = 0;
            params.web = 1;
            params.app_id = 250528;
            params.encrypt = 0;
            params.product = 'share';
            params.logid = this.getLogid();
            params.primaryid = res.shareid.value;
            params.uk = res.share_uk.value;
            params.shareType === 'secret' && (params.extra = this._getExtra());
            params.surl = this._getSurl();
        },

        detectPage() {
            let path = location.pathname;
            if (/^\/disk\/home/.test(path)) return 'home';
            if (/^\/disk\/main/.test(path)) return 'main';
            if (/^\/(s|share)\//.test(path)) return 'share';
            return '';
            return '';
        },

        showMainDialog(title, html, footer) {
            Swal.fire({
                title,
                html,
                footer,
                allowOutsideClick: false,
                showCloseButton: true,
                showConfirmButton: false,
                position: 'top',
                width,
                padding: '15px 20px 5px',
                customClass,
            }).then(() => {
                this._resetData();
            });
        },

        async initPanLinker() {
            base.initDefaultConfig();
            base.addPanLinkerStyle();
            pt = this.detectPage();
            let res = await base.post
            (`https://api.youxiaohou.com/config?ver=${version}&a=${author}`, {}, {}, 'text');
            pan = JSON.parse(base.d(res));
            Object.freeze && Object.freeze(pan);
            pan.num === base.getValue('setting_init_code') ? this.addButton() : this.addInitButton();
            base.createTip();
            base.registerMenuCommand();
        }
    };

    baidu.initPanLinker();
}

})();

  • TA的每日心情
    开心
    2024-11-21 13:37
  • 签到天数: 213 天

    [LV.7]常住居民III

    307

    主题

    4287

    回帖

    4131

    积分

    管理员

    积分
    4131

    管理员荣誉开发者油中2周年生态建设者喜迎中秋油中3周年挑战者 lv2

    发表于 2022-5-10 13:38:55 | 显示全部楼层
    重复发的意义是什么?
    上不慕古,下不肖俗。为疏为懒,不敢为狂。为拙为愚,不敢为恶。
    回复

    使用道具 举报

    该用户从未签到

    0

    主题

    26

    回帖

    26

    积分

    助理工程师

    积分
    26
    发表于 2022-5-11 16:41:27 | 显示全部楼层
    不明觉厉
    回复

    使用道具 举报

  • TA的每日心情
    开心
    19 小时前
  • 签到天数: 722 天

    [LV.9]以坛为家II

    0

    主题

    14

    回帖

    335

    积分

    高级工程师

    积分
    335
    发表于 2022-7-7 22:41:13 | 显示全部楼层
    手机版本能用吗?怎么使用?
    回复

    使用道具 举报

    发表回复

    本版积分规则

    快速回复 返回顶部 返回列表