懒人专用,全网VIP视频免费破解去广告、全网音乐直接下载、知乎增强、短视频无水印下载、百度网盘直接下载等多功能工具箱,功能可独立开关。长期更新,放心使用。v5.4

自用多功能脚本工具箱,完全免费、无广告、无需关注公众号,集合了优酷、爱奇艺、腾讯、B站(bilibili)、芒果等全网VIP视频(PC+移动端)免费破解去广告,网易云音乐、QQ音乐、酷狗、酷我、虾米、蜻蜓FM、荔枝FM、喜马拉雅等网站音乐和有声书音频免客户端下载,知乎增强(知乎视频下载、去广告、关键词屏蔽、去除侧边栏等),短视频无水印下载(抖音、快手),百度网盘直接下载,优惠券自动查询等几个自己常用的功能,且功能可独立开关。

// ==UserScript==
// @name         懒人专用,全网VIP视频免费破解去广告、全网音乐直接下载、知乎增强、短视频无水印下载、百度网盘直接下载等多功能工具箱,功能可独立开关。长期更新,放心使用。v5.4
// @namespace 	 lanhaha
// @version      5.9.0
// @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        *://pan.baidu.com/share/*
// @match        *://yun.baidu.com/share/*
// @match        *://www.aliyundrive.com/s/*
// @match        *://www.aliyundrive.com/drive*
// @match        *://cloud.189.cn/web/*
// @match        *://pan.xunlei.com/*
// @match        *://pan.quark.cn/*
// @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        *://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/*
// @match        *://*.douyin.com/*
// @match        *://*.kuaishou.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://unpkg.com/jquery@3.6.0/dist/jquery.min.js
// @require      https://unpkg.com/sweetalert2@10.16.6/dist/sweetalert2.all.min.js
// @require      https://unpkg.com/js-md5@0.7.3/build/md5.min.js
// @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),

        dyVideoDownload: GM_getValue('dyVideoDownload', 22),

        ksVideoDownload: GM_getValue('ksVideoDownload', 22),
    };

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

    /*--lang--*/
    var lang = {
        set: '设置',
        iconPosition: '图标位置',
        playVideo: '视频解析',
        playMusic: '音乐下载',
        zhNice: '知乎增强',
        videoDownload: '视频下载',
        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: '请输入关键词',
        dyVideoDownload: '抖音下载',
        ksVideoDownload: '快手下载',
        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/, areaClassName: 'mod_episode'},
                {funcName: "playVideo", node: ".container-player", nodeType: 'class', match: /v\.qq\.com\/x\/page/, areaClassName: 'mod_episode'},
                {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]\_/, areaClassName: 'qy-episode-num'},
                {funcName: "playVideo", node: ".m-video-player-wrap", nodeType: 'class', match: /^https:\/\/m.iqiyi\.com\/[vwa]\_/, areaClassName: 'm-sliding-list'},
                {funcName: "playVideo", node: ".intl-video-wrap", nodeType: 'class', match: /^https:\/\/www\.iq\.com\/play\//, areaClassName: 'm-sliding-list'},

                {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/, areaClassName: 'ep-list-wrapper report-wrap-module'},
                {funcName: "playVideo", node: ".player-container", nodeType: 'class', match: /m\.bilibili\.com\/bangumi/, areaClassName: 'ep-list-pre-container no-wrap'},
                {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/, areaClassName: 'episode-items clearfix'},

                {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\//, areaClassName: 'juji_grid'},
                //无单独播放页{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: 'kugou', match: /kugou\.com\/mixsong\//},
                {funcName: "playMusic", name: 'kuwo', match: /kuwo\.cn/},
                {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/}
            ]
        }],

        videoDownload: [{
            isOpen: GM_getValue('videoDownloadList', '22'), web: [
                {funcName: 'videoDownload', name: 'dyVideoDownload', match: /^https?:\/\/www\.douyin\.com\/?.+$/, isWebOpen: dyVideoDownload},
                {funcName: 'videoDownload', name: 'ksVideoDownload', match: /^https?:\/\/www\.kuaishou\.com\/?.+$/, isWebOpen: ksVideoDownload},
            ]
        }],

        baidu: [{
            isOpen: GM_getValue('baiduList', '22'), web: [
                {funcName: 'baidu', match: /https?:\/\/(pan.baidu.com)|(www.aliyundrive.com)|(cloud.189.cn)|pan.xunlei.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, videoDownload, 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 #eee;padding:12px 20px;display:block;
                }
                .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;
                    display:block;
                    border-bottom:1px solid #eee;
                }
                /*-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'},
                {'listName': lang.videoDownload, 'setListID': 'videoDownloadList', 'setPageID': 'videoDownloadSetPage'},
            ];

            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 videoDownloadOptionJson = [
                {'optionName': lang.dyVideoDownload, 'optionID': 'dyVideoDownload', 'default': dyVideoDownload},
                {'optionName': lang.ksVideoDownload, 'optionID': 'ksVideoDownload', 'default': ksVideoDownload},
            ];

            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='videoDownloadSetPage'>";

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

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

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

                let backColor, switchBackCorlor, display;

                let optionValue = GM_getValue(videoDownloadOptionJson[i].optionID, videoDownloadOptionJson[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>" + videoDownloadOptionJson[i].optionName + "</span>";

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

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

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

                setHtml += "</li>";
            }

            setHtml += "</ul>";

            setHtml += "</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 href='https://80note.com/2019/05/782.html' target='_blank'>" + lang.question + "</a></li>・<li><a href='https://www.zuihuimai.net/t/qq.html' target='_blank'>交流群</a></li>・<li><a href='https://cdn.80note.com/ds.jpg' target='_blank'>" + lang.reward + "</a></li>・<li><a href='https://cdn.80note.com/erwwma.png' target='_blank'>" + lang.redReward + "</a></li>・<li><a href='https://80note.com/2022/03/323.html' 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;

            }
        }

        static getElement(css) {

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

                let num = 0;

                let timer = setInterval(function () {

                    num++;

                    let dom = document.querySelector(css);

                    if (dom) {

                        clearInterval(timer);

                        resolve(dom);

                    } else {

                        if (num == 20) {
                            clearInterval(timer);
                            resolve(false);
                        }
                    }

                }, 300);

            });

        }
    }

    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';
                        }
                    }

                });
            });
        }
    }

    class VideoDownloadClass extends BaseClass {

        constructor() {

            super();
        }

        dyVideoDownload() {

            var _this = this;

            window.addEventListener('load', function () {

                async function getControls() {

                    let videoDom = await BaseClass.getElement('.xg-video-container');

                    if (!videoDom) {

                        console.log('没有找到DOM');
                        return;
                    }

                    let vsNav = document.querySelector('.fuy_wmct:nth-of-type(5)');

                    if ((vsNav && vsNav.className.indexOf('LXX79le5') != -1) || couponUrl.indexOf('vsdetail') != -1) {
                        console.log('综艺栏目关闭下载');
                        return;
                    }

                    _this.createDyVideoDownload();

                    let videoPlayDomAll = document.querySelectorAll('video');

                    let videoPlayDom = videoPlayDomAll.length > 1 ? videoPlayDomAll[videoPlayDomAll.length - 2] : videoPlayDomAll[videoPlayDomAll.length - 1];

                    videoPlayDom.addEventListener('ended', function () { //结束

                        console.log("播放结束");

                        let autoPlay = document.querySelector('.xg-switch-checked');

                        if (autoPlay) {

                            getControls();
                            return;
                        }

                    }, false);

                    document.querySelector('#zhmDouyinDownload').addEventListener('click', function () {

                        let dataUrl = this.getAttribute('data-url');

                        let match = /[https]?:?\/\/www\.douyin\.com\/.+\/([0-9]+)/;

                        let video = dataUrl.match(match);

                        let videoId = video[1];

                        let url = 'https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids=' + video[1];

                        let uri = videoDownloadClass.request('get', url).then((result) => {

                            let resp = JSON.parse(result);

                            //let playUrl = resp.item_list[0].video.play_addr.url_list[0];//下载有水印

                            if (resp.item_list.length > 0) {

                                let uriId = resp.item_list[0].video.play_addr.uri;

                                let playUrl = `https://aweme.snssdk.com/aweme/v1/play/?video_id=${uriId}&line=0&ratio=540p&media_type=4&vr_type=0&improve_bitrate=0&is_play_url=1&is_support_h265=0&source=PackSourceEnum_PUBLISH`;

                                GM_download(playUrl, videoId + ".mp4");

                            } else {
                                console.log('API没有获取视频ID');
                            }

                        }).catch((error) => {
                            console.log(error);
                        });

                    });
                    return;
                }

                getControls();

                window.addEventListener("wheel", getControls);

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

                    if (e.code == 'ArrowDown' || e.code == 'ArrowUp') {

                        getControls();
                    }

                });

                async function insertedDom() {

                    let videoDom = await BaseClass.getElement('video');

                    if (!videoDom) {

                        console.log('没有找到DOM');
                        return;
                    }

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

                        getControls();

                    });

                }

                insertedDom();

                window.addEventListener('click', getControls);
            });

        }

        createDyVideoDownload() {

            let controlAll = document.querySelectorAll('.xg-right-grid');

            let controls = controlAll.length > 1 ? controlAll[controlAll.length - 2] : controlAll[controlAll.length - 1];

            let videoDownloadDom = document.querySelector('#zhmDouyinDownload');

            if (videoDownloadDom) {

                videoDownloadDom.parentNode.removeChild(videoDownloadDom);
            }

            let detailDom = controls.querySelector('xg-icon:nth-of-type(1)');

            let xgIcon = detailDom.cloneNode(true);

            if (xgIcon.children[1] && xgIcon.children[1].className == 'xg-tips') {

                xgIcon.children[1].innerHTML = '下载视频';
            }

            xgIcon.className = 'xgplayer-detail-entry player-line';

            xgIcon.children[0].style = 'margin-right:16px;';

            xgIcon.children[0].setAttribute('id', 'zhmDouyinDownload');

            let linkUrl = xgIcon.children[0].getAttribute('href') ? xgIcon.children[0].getAttribute('href') : location.href;

            xgIcon.children[0].setAttribute('data-url', linkUrl);

            xgIcon.children[0].removeAttribute('target');

            xgIcon.children[0].setAttribute('href', 'javascript:void(0);');

            xgIcon.children[0].innerHTML = "<div class='desc' style='font-size:12px;line-height:20px;'>下载</div>";

            let autoPlay = document.querySelector('.xgplayer-autoplay-setting');

            autoPlay.after(xgIcon);

        }

        ksVideoDownload() {

            var _this = this;

            window.addEventListener('load', function () {

                async function getControls() {

                    let videoDom = await BaseClass.getElement('.player-video');

                    if (!videoDom) {

                        console.log('没有找到DOM');
                        return;

                    }

                    if (videoDom.getAttribute('src').match(/^blob/)) {
                        console.log('blob视频无法下载');
                        return;
                    }

                    _this.createKsVideoDownload(videoDom);

                    videoDom.addEventListener('playing', function () { //播放中
                        console.log("播放中");
                    });

                    videoDom.addEventListener('ended', function () { //结束
                        console.log("播放结束");
                        let autoPlay = document.querySelector('.auto-warpper').getAttribute('autoplay');

                        if (autoPlay) {
                            getControls();
                            return;

                        }

                    }, false);

                    document.querySelector('#zhmKsDownload').addEventListener('click', function () {

                        let playTimeTotal = document.querySelector('.total').innerText;

                        let second = playTimeTotal.match(/(.+):(.+)/);

                        let secondTotal = second[1] * 60 + parseInt(second[2]);

                        let dataUrl = this.getAttribute('data-url');

                        let videoFileName = new Date().getTime() + '.mp4';

                        GM_download(dataUrl, videoFileName);

                        /*

                        if(secondTotal<30){

                            let videoFileName = new Date().getTime()+'.mp4';

                            GM_download(dataUrl,videoFileName);

                        }else{

                            window.open(dataUrl);
                        }
                        */
                    });

                }

                getControls();

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

                    getControls();


                });

            });


        }

        createKsVideoDownload(videoDom) {

            let match = /^https?:\/\/www\.kuaishou\.com\/(.+)\/.+/;

            let resp = location.href.match(match);

            if (!resp || (resp[1] != 'short-video' && resp[1] != 'video')) {

                console.log('当前不是视频播放页');
                return;
            }

            if (resp[1] == 'short-video') {

                let playerArea = document.querySelector('.video-container-player');

                let playerAreaWidth = playerArea.style.width.match(/(.+)px/);

                let playerBarProgress = document.querySelector('.player-bar-progress');

                playerBarProgress.style.width = playerAreaWidth[1] - 260 + 'px';

                let timeTotal = document.querySelector('.total');

                timeTotal.style.right = '120px';
            }

            let controls = document.querySelector('.right');

            let videoDownloadDom = document.querySelector('#zhmKsDownload');

            if (videoDownloadDom) {

                videoDownloadDom.parentNode.removeChild(videoDownloadDom);
            }

            let detailDom = controls.querySelector('div:nth-of-type(1)');

            let xgIcon = detailDom.cloneNode(true);

            let linkUrl = videoDom.getAttribute('src');

            xgIcon.setAttribute('data-url', linkUrl);

            xgIcon.setAttribute('id', 'zhmKsDownload');

            xgIcon.innerHTML = "<div style='cursor:pointer;'>下载</div>";

            detailDom.before(xgIcon);

            //重构播放操作按钮

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

            //console.log(zhmKsButton);

            if (zhmKsButton) {

                //zhmKsButton.parentNode.removeChild(zhmKsButton);

                return false;
            }

            let buttonIcon = detailDom.cloneNode(true);
            //console.log(buttonIcon);
            buttonIcon.setAttribute('id', 'zhmKsButton');

            let buttonIconImg = buttonIcon.querySelector('.unmuted-icon');

            buttonIconImg.style = 'background: url(https://s2-10623.kwimgs.com/udata/pkg/cloudcdn/img/player-setting.ad1f5ce8.svg) no-repeat';

            detailDom.after(buttonIcon);

            let plSlider = buttonIcon.querySelector('.pl-slider');

            plSlider.style = 'width:auto;padding:10px 10px 25px 10px;';

            plSlider.innerHTML = "";

            let buttonFour = controls.querySelector('div:nth-of-type(4)');

            buttonFour.style.margin = '0px';

            let autoPlay = document.querySelector('.play-setting-container');

            autoPlay.style.margin = '0px 40px 0px 0px';

            let buttonFive = controls.querySelector('div:nth-of-type(5)');

            buttonFive.style.margin = '15px 0px';

            buttonFive.onmouseover = function () {

                setTimeout(function () {

                    let toolTip = document.querySelector('.kwai-player-rotate-tooltip');

                    if (toolTip) {

                        toolTip.parentNode.removeChild(toolTip);
                    }


                }, 30);

            };

            let buttonSix = controls.querySelector('div:nth-of-type(6)');

            buttonSix.style.margin = '15px 0px';

            let toolTip = document.querySelector('.kwai-player-fullscreen-tooltip');

            buttonSix.onmouseover = function () {

                setTimeout(function () {


                    let toolTip = document.querySelector('.kwai-player-fullscreen-tooltip');

                    if (toolTip) {

                        toolTip.parentNode.removeChild(toolTip);

                    }

                }, 30);

            };

            plSlider.appendChild(buttonFour);

            plSlider.appendChild(buttonFive);

            plSlider.appendChild(buttonSix);


        }

    }

    var allWeb = [...getCoupon, ...jxVideo, ...jxMusic, ...zhNice, ...videoDownload, ...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];

    switch (funcName) {
        case 'playVideo':
            var playVideoClass = new PlayVideoClass();
            playVideoFunc();
            break;
        case 'playMusic':
            playMusicFunc();
            break;
        case 'zhNice':
            var zhClass = new ZhClass();
            zhNiceFunc();
            break;
        case 'baidu':
            baiduFunc();
            break;
        case 'videoDownload':
            var videoDownloadClass = new VideoDownloadClass();
            if (nowWeb[0].isWebOpen == 0) {
                console.log(nowWeb[0].name + '已关闭');
                return;
            } else {
                videoDownloadClass[nowName]();
            }
            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>";

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

            setTimeout(function () {

                let jBlock = document.querySelectorAll('.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);
                }
            }, 3000);
        }

        //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 => {
                            });

                        }
                    });

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

                        let areaClassName = [];

                        e.path.filter(function (item) {


                            if (item.className == nowWeb[0].areaClassName) {

                                areaClassName = item;

                            }
                            ;

                        });

                        console.log(areaClassName);

                        if (areaClassName.length == 0) {
                            console.log('不在选集范围');
                            return;
                        }

                        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 && objLink.target != '_blank') {

                            location.href = objLink.href;

                            return;
                        }
                    });

                }, iconWaitTime);

            } else {

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

            }
        }, 1000);
    }

    function playMusicFunc() {

        var playMusicClass = new PlayMusicClass();

        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); // 取消定时器

                    if (jxMusicWeb[0].name == 'kuwo') {

                        setTimeout(function () {

                            let control = document.querySelector('.icon-bar_icon_download_');

                            let icon = control.cloneNode(true);

                            icon.className = '';

                            icon.style = 'margin-left:10px;';

                            icon.innerHTML = "<a style='font-size:10px;white-space: nowrap;cursor:pointer;color:#555;' id='kuwoDownload'>下载</a>";

                            let controls = document.querySelector('.col_r');

                            controls.before(icon);

                            document.querySelector('#kuwoDownload').addEventListener('click', function () {

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

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

                                GM_download(audioSrc, new Date().getTime() + '.mp3');

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

                                //window.open(openUrl);

                            });

                        }, 2000);
                    }

                    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() {

                                document.querySelector('.playControl').style = 'bottom:0px';

                                alert('请点击播放需要下载的歌曲,然后在网页下方播放器内点击"下载"。');

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

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

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

                                window.open(openUrl);
                                */
                            }

                            function ximalayaFun() {

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

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

                                if (urlInfo[1]) {

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

                                } else {

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

                        });

                    }, iconWaitTime);

                } else {

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

            });

        } else {

            let zhmPlayDom = document.querySelector('#zhmIcon');

            if (zhmPlayDom) {

                zhmPlayDom.parentNode.removeChild(zhmPlayDom);

            }

            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() {
        (function () {
            'use strict';

            let pt = '', selectList = [], params = {}, mode = '', width = 800, pan = {}, color = '',
                doc = $(document), progress = {}, request = {}, ins = {}, idm = {};
            const scriptInfo = GM_info.script;
            const version = scriptInfo.version;
            const author = scriptInfo.author;
            const name = scriptInfo.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 = {

                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 '';
                },

                isType(obj) {
                    return Object.prototype.toString.call(obj).replace(/^\[object (.+)\]$/, '$1').toLowerCase();
                },

                getValue(name) {
                    return GM_getValue(name);
                },

                setValue(name, value) {
                    GM_setValue(name, value);
                },

                getStorage(key) {
                    try {
                        return JSON.parse(localStorage.getItem(key));
                    } catch (e) {
                        return localStorage.getItem(key);
                    }
                },

                setStorage(key, value) {
                    if (this.isType(value) === 'object' || this.isType(value) === 'array') {
                        return localStorage.setItem(key, JSON.stringify(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 (this.isType(data) === '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);
                            },
                        });
                    });
                },

                getFinalUrl(url, headers) {
                    return new Promise((resolve, reject) => {
                        let requestObj = GM_xmlhttpRequest({
                            method: "GET", url, headers,
                            onload: (res) => {
                                resolve(res.finalUrl);
                            },
                            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);
                },

                findReact(dom, traverseUp = 0) {
                    const key = Object.keys(dom).find(key => {
                        return key.startsWith("__reactFiber$")
                            || key.startsWith("__reactInternalInstance$");
                    });
                    const domFiber = dom[key];
                    if (domFiber == null) return null;

                    if (domFiber._currentElement) {
                        let compFiber = domFiber._currentElement._owner;
                        for (let i = 0; i < traverseUp; i++) {
                            compFiber = compFiber._currentElement._owner;
                        }
                        return compFiber._instance;
                    }

                    const GetCompFiber = fiber => {
                        let parentFiber = fiber.return;
                        while (typeof parentFiber.type == "string") {
                            parentFiber = parentFiber.return;
                        }
                        return parentFiber;
                    };
                    let compFiber = GetCompFiber(domFiber);
                    for (let i = 0; i < traverseUp; i++) {
                        compFiber = GetCompFiber(compFiber);
                    }
                    return compFiber.stateNode || compFiber;
                },

                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);
                },

                getMirrorList(link, mirror, thread = 2) {
                    let host = new URL(link).host;
                    let mirrors = [];
                    for (let i = 0; i < mirror.length; i++) {
                        for (let j = 0; j < thread; j++) {
                            let item = link.replace(host, mirror[i]) + '&'.repeat(j);
                            mirrors.push(item);
                        }
                    }
                    return mirrors.join('\n');
                },

                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; }
            .ali-button {display: inline-flex;align-items: center;justify-content: center;border: 0 solid transparent;border-radius: 5px;box-shadow: 0 0 0 0 transparent;width: fit-content;white-space: nowrap;flex-shrink: 0;font-size: 14px;line-height: 1.5;outline: 0;touch-action: manipulation;transition: background .3s ease,color .3s ease,border .3s ease,box-shadow .3s ease;color: #fff;background: rgb(99 125 255);margin-left: 20px;padding: 1px 12px;position: relative; cursor:pointer; height: 32px;}
            .ali-button:hover {background: rgb(122, 144, 255)}
            .tianyi-button {margin-right: 20px; padding: 4px 12px; border-radius: 4px; color: #fff; font-size: 12px; border: 1px solid #0073e3; background: #2b89ea; cursor: pointer; position: relative;}
            .tianyi-button:hover {border-color: #1874d3; background: #3699ff;}
            .xunlei-button {display: inline-flex;align-items: center;justify-content: center;border: 0 solid transparent;border-radius: 5px;box-shadow: 0 0 0 0 transparent;width: fit-content;white-space: nowrap;flex-shrink: 0;font-size: 14px;line-height: 1.5;outline: 0;touch-action: manipulation;transition: background .3s ease,color .3s ease,border .3s ease,box-shadow .3s ease;color: #fff;background: #3f85ff;margin-left: 12px;padding: 0px 12px;position: relative; cursor:pointer; height: 36px;}
            .xunlei-button:hover {background: #619bff}
            .quark-button {display: inline-flex; align-items: center; justify-content: center; border: 1px solid #ddd; border-radius: 8px; white-space: nowrap; flex-shrink: 0; font-size: 14px; line-height: 1.5; outline: 0; color: #333; background: #fff; margin-right: 10px; padding: 0px 14px; position: relative; cursor: pointer; height: 36px;}
            .quark-button:hover { background:#f6f6f6 }
            .pl-dropdown-menu {position: absolute;right: 0;top: 30px;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 .pl-dropdown-menu { display: none; }
            .pl-button:hover .pl-dropdown-menu { display: block!important; }
            .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: pan.init[0],
                        html: `<div><img style="width: 250px;margin-bottom: 10px;" src="${pan.img}" alt="${pan.img}"><input class="swal2-input" id="init" type="text" placeholder="${pan.init[1]}"></div>`,
                        allowOutsideClick: false,
                        showCloseButton: true,
                        confirmButtonText: '确定'
                    });
                    if (result.isDismissed && result.dismiss === 'close') return;
                    if (pan.num === $('#init').val()) {
                        base.setValue('setting_init_code', pan.num);
                        message.success(pan.init[2]);
                        setTimeout(() => {
                            history.go(0);
                        }, 1500);
                    } else {
                        await Swal.fire({
                            title: pan.init[3],
                            text: pan.init[4],
                            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", {BDUSS: cookies[0].value});
                            }
                        });
                    } catch (e) {
                    }
                },

                getBDUSS() {
                    let baiduyunPlugin_BDUSS = base.getStorage('baiduyunPlugin_BDUSS') ? base.getStorage('baiduyunPlugin_BDUSS') : '{"baiduyunPlugin_BDUSS":""}';
                    return 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]
                    };
                },

                convertLinkToBC(link, filename, ua) {
                    let BDUSS = this.getBDUSS();
                    if (!!BDUSS) {
                        let cookie = `BDUSS=${BDUSS}`;
                        let bc = `AA/${encodeURIComponent(filename)}/?url=${encodeURIComponent(link)}&cookie=${encodeURIComponent(cookie)}&user_agent=${encodeURIComponent(ua)}ZZ`;
                        return encodeURIComponent(`bc://http/${base.e(bc)}`);
                    }
                    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.g-dropdown-button', (e) => {
                        if (e.type === 'mouseleave') {
                            $(e.currentTarget).removeClass('button-open');
                        } else {
                            $(e.currentTarget).addClass('button-open');
                            $(e.currentTarget).find('.pl-dropdown-menu').show();
                        }
                    });
                    doc.on('mouseleave', '.pl-button.g-dropdown-button .pl-dropdown-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 style="color:${color}" class="g-button-menu pl-button-mode" data-mode="bc">BC下载</div>${pan.code == 200 && version < pan.version ? pan.new : ''}</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-dropdown-menu"><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><li class="sub cursor-p pl-button-mode" data-mode="bc" >BC下载</li>${pan.code == 200 && version < pan.version ? pan.newX : ''}</ul></div>`);
                    }
                    if (pt === 'share') $toolWrap = $(pan.btn.share);
                    $toolWrap.prepend($button);
                    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>`;
                            }
                        }
                        if (mode === 'bc') {
                            let alink = this.convertLinkToBC(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" href="${decodeURIComponent(alink.link)}" title="点击用比特彗星下载" data-filename="${filename}" data-link="${alink}">${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" href="${decodeURIComponent(alink)}" title="点击用比特彗星下载" 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('.wp-s-core-pan').__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();
                }
            };

            let ali = {

                convertLinkToAria(link, filename, ua) {
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`aria2c "${link}" --out "${filename}" --header "Referer: https://www.aliyundrive.com/"`);
                },

                convertLinkToBC(link, filename, ua) {
                    let bc = `AA/${encodeURIComponent(filename)}/?url=${encodeURIComponent(link)}&refer=${encodeURIComponent('https://www.aliyundrive.com/')}ZZ`;
                    return encodeURIComponent(`bc://http/${base.e(bc)}`);
                },

                convertLinkToCurl(link, filename, ua) {
                    let terminal = base.getValue('setting_terminal_type');
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`${terminal !== 'wp' ? 'curl' : 'curl.exe'} -L "${link}" --output "${filename}" -e "https://www.aliyundrive.com/"`);
                },

                addPageListener() {
                    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 dataset = e.currentTarget.dataset;
                        let href = dataset.link;
                        let url = await this.getRealLink(dataset.did, dataset.fid);
                        if (url) href = url;
                        let d = document.createElement("a");
                        d.download = e.currentTarget.dataset.filename;
                        d.rel = "noopener";
                        d.href = href;
                        d.dispatchEvent(new MouseEvent("click"));
                    });
                    doc.on('click', '.listener-link-aria, .listener-copy-all', (e) => {
                        e.preventDefault();
                        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 {
                            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});
                    });
                },

                async getRealLink(d, f) {
                    let authorization = `${base.getStorage('token').token_type} ${base.getStorage('token').access_token}`;
                    let res = await base.post(pan.pcs[1], {
                        drive_id: d,
                        file_id: f
                    }, {
                        authorization,
                        "content-type": "application/json;charset=utf-8",
                    });
                    if (res.url) {
                        return res.url;
                    }
                    return '';
                },

                addButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="ali-button pl-button"><svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M853.333 938.667H170.667a85.333 85.333 0 0 1-85.334-85.334v-384A85.333 85.333 0 0 1 170.667 384H288a32 32 0 0 1 0 64H170.667a21.333 21.333 0 0 0-21.334 21.333v384a21.333 21.333 0 0 0 21.334 21.334h682.666a21.333 21.333 0 0 0 21.334-21.334v-384A21.333 21.333 0 0 0 853.333 448H736a32 32 0 0 1 0-64h117.333a85.333 85.333 0 0 1 85.334 85.333v384a85.333 85.333 0 0 1-85.334 85.334z" fill="#fff"/><path d="M715.03 543.552a32.81 32.81 0 0 0-46.251 0L554.005 657.813v-540.48a32 32 0 0 0-64 0v539.734L375.893 543.488a32.79 32.79 0 0 0-46.229 0 32.427 32.427 0 0 0 0 46.037l169.557 168.811a32.81 32.81 0 0 0 46.251 0l169.557-168.81a32.47 32.47 0 0 0 0-45.974z" fill="#FF9C00"/></svg><ul class="pl-dropdown-menu"><li class="pl-dropdown-menu-item pl-button-mode" data-mode="api">API下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="aria" >Aria下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="rpc">RPC下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="curl">cURL下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="bc" >BC下载</li>${pan.code == 200 && version < pan.version ? pan.new : ''}</ul></div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.append($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    base.createDownloadIframe();
                    this.addPageListener();
                },

                addInitButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="ali-button pl-button-init"><svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M853.333 938.667H170.667a85.333 85.333 0 0 1-85.334-85.334v-384A85.333 85.333 0 0 1 170.667 384H288a32 32 0 0 1 0 64H170.667a21.333 21.333 0 0 0-21.334 21.333v384a21.333 21.333 0 0 0 21.334 21.334h682.666a21.333 21.333 0 0 0 21.334-21.334v-384A21.333 21.333 0 0 0 853.333 448H736a32 32 0 0 1 0-64h117.333a85.333 85.333 0 0 1 85.334 85.333v384a85.333 85.333 0 0 1-85.334 85.334z" fill="#fff"/><path d="M715.03 543.552a32.81 32.81 0 0 0-46.251 0L554.005 657.813v-540.48a32 32 0 0 0-64 0v539.734L375.893 543.488a32.79 32.79 0 0 0-46.229 0 32.427 32.427 0 0 0 0 46.037l169.557 168.811a32.81 32.81 0 0 0 46.251 0l169.557-168.81a32.47 32.47 0 0 0 0-45.974z" fill="#FF9C00"/></svg></div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.append($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    $button.click(() => base.initDialog());
                },

                async getPCSLink() {
                    let reactDomGrid = document.getElementsByClassName(pan.dom.grid)[0];
                    if (reactDomGrid) {
                        let res = await Swal.fire({
                            title: '提示',
                            html: '<div style="display: flex;align-items: center;justify-content: center;">请先切换到 <b>列表视图</b>(<svg class="icon" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M132 928c-32.8 0-59.2-26.4-59.2-59.2s26.4-59.2 59.2-59.2h760c32.8 0 59.2 26.4 59.2 59.2S924.8 928 892 928H132zm0-356.8c-32.8 0-59.2-26.4-59.2-59.2s26.4-59.2 59.2-59.2h760c32.8 0 59.2 26.4 59.2 59.2s-26.4 59.2-59.2 59.2H132zm0-356c-32.8 0-59.2-26.4-59.2-59.2S99.2 96.8 132 96.8h760c32.8 0 59.2 26.4 59.2 59.2s-26.4 59.2-59.2 59.2H132z"/></svg>)后获取!</div>',
                            confirmButtonText: '点击切换'
                        });
                        if (res) {
                            $('.switch-wrapper--1yEfx').trigger('click');
                            return message.success('切换成功,请重新获取下载链接!');
                        }
                        return false;
                    }
                    selectList = this.getSelectedList();
                    if (selectList.length === 0) {
                        return message.error('提示:请先勾选要下载的文件!');
                    }
                    if (this.isOnlyFolder()) {
                        return message.error('提示:请打开文件夹后勾选文件!');
                    }
                    if (pt === 'share') {
                        if (selectList.length > 20) {
                            return message.error('提示:单次最多可勾选 20 个文件!');
                        }
                        try {
                            let authorization = `${base.getStorage('token').token_type} ${base.getStorage('token').access_token}`;
                            let xShareToken = base.getStorage('shareToken').share_token;

                            for (let i = 0; i < selectList.length; i++) {
                                let res = await base.post(pan.pcs[0], {
                                    expire_sec: 600,
                                    file_id: selectList[i].fileId,
                                    share_id: selectList[i].shareId
                                }, {
                                    authorization,
                                    "content-type": "application/json;charset=utf-8",
                                    "x-share-token": xShareToken
                                });
                                if (res.download_url) {
                                    selectList[i].downloadUrl = res.download_url;
                                }
                            }
                        } catch (e) {
                            return message.error('提示:请先登录网盘!');
                        }
                    }
                    let html = this.generateDom(selectList);
                    this.showMainDialog(pan[mode][0], html, pan[mode][1]);
                },

                generateDom(list) {
                    let content = '<div class="pl-main">';
                    let alinkAllText = '';
                    list.forEach((v, i) => {
                        if (v.type === 'folder') return;
                        let filename = v.name;
                        let fid = v.fileId;
                        let did = v.driveId;
                        let size = base.sizeFormat(v.size);
                        let dlink = v.downloadUrl || v.url;
                        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 listener-link-api" data-did="${did}" data-fid="${fid}" data-filename="${filename}" data-link="${dlink}" data-index="${i}">${dlink}</a>
                                </div>`;
                        }
                        if (mode === 'aria') {
                            let alink = this.convertLinkToAria(dlink, filename, navigator.userAgent);
                            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" 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 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, navigator.userAgent);
                            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" 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 listener-link-aria" href="${alink}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> </div>`;
                            }
                        }
                        if (mode === 'bc') {
                            let alink = this.convertLinkToBC(dlink, filename, navigator.userAgent);
                            content += `<div class="pl-item">
                                <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                                <a class="pl-item-link" href="${decodeURIComponent(alink)}" title="点击用比特彗星下载" 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 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: [`Referer: https://www.aliyundrive.com/`]
                        }]
                    };
                    try {
                        let res = await base.post(url, rpcData, {"Referer": "https://www.aliyundrive.com/"}, '');
                        if (res.result) return 'success';
                        return 'fail';
                    } catch (e) {
                        return 'fail';
                    }
                },

                getSelectedList() {
                    try {
                        let selectedList = [];
                        let reactDom = document.getElementsByClassName(pan.dom.list)[0];
                        let reactObj = base.findReact(reactDom, 1);
                        let props = reactObj.pendingProps;
                        if (props) {
                            let fileList = props.dataSource || [];
                            let selectedKeys = props.selectedKeys.split(',');
                            fileList.forEach((val) => {
                                if (selectedKeys.includes(val.fileId)) {
                                    selectedList.push(val);
                                }
                            });
                        }
                        return selectedList;
                    } catch (e) {
                        return [];
                    }
                },

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

                isOnlyFolder() {
                    for (let i = 0; i < selectList.length; i++) {
                        if (selectList[i].type === 'file') return false;
                    }
                    return true;
                },

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

                async initPanLinker() {
                    base.initDefaultConfig();
                    base.addPanLinkerStyle();
                    pt = this.detectPage();
                    let res = await base.post
                    (`https://api.youxiaohou.com/config/ali?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();
                }
            };

            let tianyi = {

                convertLinkToAria(link, filename, ua) {
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`aria2c "${link}" --out "${filename}"`);
                },

                convertLinkToBC(link, filename, ua) {
                    let bc = `AA/${encodeURIComponent(filename)}/?url=${encodeURIComponent(link)}ZZ`;
                    return encodeURIComponent(`bc://http/${base.e(bc)}`);
                },

                convertLinkToCurl(link, filename, ua) {
                    let terminal = base.getValue('setting_terminal_type');
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`${terminal !== 'wp' ? 'curl' : 'curl.exe'} -L "${link}" --output "${filename}"`);
                },

                addPageListener() {
                    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();
                        $('#downloadIframe').attr('src', e.currentTarget.dataset.link);
                    });
                    doc.on('click', '.listener-link-aria, .listener-copy-all', (e) => {
                        e.preventDefault();
                        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 {
                            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});
                    });
                },

                addButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="tianyi-button pl-button">下载助手<ul class="pl-dropdown-menu" style="top: 26px;"><li class="pl-dropdown-menu-item pl-button-mode" data-mode="api">API下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="aria" >Aria下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="rpc">RPC下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="curl">cURL下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="bc" >BC下载</li>${pan.code == 200 && version < pan.version ? pan.new : ''}</ul></div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    base.createDownloadIframe();
                    this.addPageListener();
                },

                addInitButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="tianyi-button pl-button-init">下载助手</div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.append($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    $button.click(() => base.initDialog());
                },

                async getToken() {
                    let res = await base.getFinalUrl(pan.pcs[1], {});
                    let accessToken = res.match(/accessToken=(\w+)/)?.[1];
                    accessToken && base.setStorage('accessToken', accessToken);
                    return accessToken;
                },

                async getFileUrlByOnce(item, index, token) {
                    try {
                        if (item.downloadUrl) return {
                            index,
                            downloadUrl: item.downloadUrl
                        };
                        let time = Date.now(),
                            fileId = item.fileId,
                            o = "AccessToken=" + token + "&Timestamp=" + time + "&fileId=" + fileId,
                            url = pan.pcs[2] + '?fileId=' + fileId;
                        if (item.shareId) {
                            o = "AccessToken=" + token + "&Timestamp=" + time + "&dt=1&fileId=" + fileId + "&shareId=" + item.shareId;
                            url += '&dt=1&shareId=' + item.shareId;
                        }
                        let sign = md5(o).toString();
                        let res = await base.get(url, {
                            "accept": "application/json;charset=UTF-8",
                            "sign-type": 1,
                            "accesstoken": token,
                            "timestamp": time,
                            "signature": sign
                        });
                        if (res.res_code === 0) {
                            return {
                                index,
                                downloadUrl: res.fileDownloadUrl
                            };
                        } else if (res.errorCode === 'InvalidSessionKey') {
                            return {
                                index,
                                downloadUrl: '提示:请先登录网盘!'
                            };
                        } else if (res.res_code === 'ShareNotFoundFlatDir') {
                            return {
                                index,
                                downloadUrl: '提示:请先[转存]文件,👉前往[我的网盘]中下载!'
                            };
                        } else {
                            return {
                                index,
                                downloadUrl: '获取下载地址失败,请刷新重试!'
                            };
                        }
                    } catch (e) {
                        return {
                            index,
                            downloadUrl: '获取下载地址失败,请刷新重试!'
                        };
                    }
                },

                async getPCSLink() {
                    selectList = this.getSelectedList();
                    if (selectList.length === 0) {
                        return message.error('提示:请先勾选要下载的文件!');
                    }
                    if (this.isOnlyFolder()) {
                        return message.error('提示:请打开文件夹后勾选文件!');
                    }
                    let token = base.getStorage('accessToken') || await this.getToken();
                    if (!token) {
                        return message.error('提示:请先登录网盘!');
                    }
                    let queue = [];
                    selectList.forEach((item, index) => {
                        queue.push(this.getFileUrlByOnce(item, index, token));
                    });

                    const res = await Promise.all(queue);
                    res.forEach(val => {
                        selectList[val.index].downloadUrl = val.downloadUrl;
                    });

                    let html = this.generateDom(selectList);
                    this.showMainDialog(pan[mode][0], html, pan[mode][1]);
                },

                generateDom(list) {
                    let content = '<div class="pl-main">';
                    let alinkAllText = '';
                    list.forEach((v, i) => {
                        if (v.isFolder) return;
                        let filename = v.fileName;
                        let size = base.sizeFormat(v.size);
                        let dlink = v.downloadUrl;
                        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 listener-link-api" data-filename="${filename}" data-link="${dlink}" data-index="${i}">${dlink}</a>
                                </div>`;
                        }
                        if (mode === 'aria') {
                            let alink = this.convertLinkToAria(dlink, filename, navigator.userAgent);
                            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" target="_blank" href="${alink.link}" title="点击复制aria2c链接" data-filename="${filename}" data-link="${alink.link}">${decodeURIComponent(alink.text)}</a> </div>`;
                            } else {
                                content += `<div class="pl-item">
                                <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                                <a class="pl-item-link 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, navigator.userAgent);
                            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" target="_blank" href="${alink.link}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink.link}">${decodeURIComponent(alink.text)}</a> </div>`;
                            } else {
                                content += `<div class="pl-item">
                                <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                                <a class="pl-item-link listener-link-aria" href="${alink}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> </div>`;
                            }
                        }
                        if (mode === 'bc') {
                            let alink = this.convertLinkToBC(dlink, filename, navigator.userAgent);
                            content += `<div class="pl-item">
                                <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                                <a class="pl-item-link" href="${decodeURIComponent(alink)}" title="点击用比特彗星下载" 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 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: []
                        }]
                    };
                    try {
                        let res = await base.post(url, rpcData, {}, '');
                        if (res.result) return 'success';
                        return 'fail';
                    } catch (e) {
                        return 'fail';
                    }
                },

                getSelectedList() {
                    try {
                        return document.querySelector(".c-file-list").__vue__.selectedList;
                    } catch (e) {
                        return [document.querySelector(".info-detail").__vue__.fileDetail];
                    }
                },

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

                isOnlyFolder() {
                    for (let i = 0; i < selectList.length; i++) {
                        if (!selectList[i].isFolder) return false;
                    }
                    return true;
                },

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

                async initPanLinker() {
                    base.initDefaultConfig();
                    base.addPanLinkerStyle();
                    pt = this.detectPage();
                    let res = await base.post
                    (`https://api.youxiaohou.com/config/tianyi?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();
                    this.getToken();
                    base.createTip();
                    base.registerMenuCommand();
                }
            };

            let xunlei = {

                convertLinkToAria(link, filename, ua) {
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`aria2c "${link}" --out "${filename}"`);
                },

                convertLinkToBC(link, filename, ua) {
                    let bc = `AA/${encodeURIComponent(filename)}/?url=${encodeURIComponent(link)}ZZ`;
                    return encodeURIComponent(`bc://http/${base.e(bc)}`);
                },

                convertLinkToCurl(link, filename, ua) {
                    let terminal = base.getValue('setting_terminal_type');
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`${terminal !== 'wp' ? 'curl' : 'curl.exe'} -L "${link}" --output "${filename}"`);
                },

                addPageListener() {
                    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();
                        $('#downloadIframe').attr('src', e.currentTarget.dataset.link);
                    });
                    doc.on('click', '.listener-link-api-btn', async (e) => {
                        base.setClipboard(e.target.dataset.filename);
                        $(e.target).text('复制成功').animate({opacity: '0.5'}, "slow");
                    });
                    doc.on('click', '.listener-link-bc-btn', async (e) => {
                        let mirror = base.getMirrorList(e.target.dataset.dlink, pan.mirror);
                        base.setClipboard(mirror);
                        $(e.target).text('复制成功').animate({opacity: '0.5'}, "slow");
                    });
                    doc.on('click', '.listener-link-aria, .listener-copy-all', (e) => {
                        e.preventDefault();
                        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 {
                            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});
                    });
                },

                addButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="xunlei-button pl-button"><i class="xlpfont xlp-download"></i><span style="font-size: 13px;margin-left: 6px;">下载助手</span><ul class="pl-dropdown-menu" style="top: 34px;"><li class="pl-dropdown-menu-item pl-button-mode" data-mode="api">API下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="aria" >Aria下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="rpc">RPC下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="curl">cURL下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="bc" >BC下载</li>${pan.code == 200 && version < pan.version ? pan.new : ''}</ul></div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    base.createDownloadIframe();
                    this.addPageListener();
                },

                addInitButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="xunlei-button pl-button-init"><i class="xlpfont xlp-download"></i><span style="font-size: 13px;margin-left: 6px;">下载助手</span></div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.append($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    $button.click(() => base.initDialog());
                },

                getToken() {
                    let credentials = {}, captcha = {};
                    for (let i = 0; i < localStorage.length; i++) {
                        if (/^credentials_/.test(localStorage.key(i))) {
                            credentials = base.getStorage(localStorage.key(i));
                            base.setStorage('');
                        }
                        if (/^captcha_[\w]{16}/.test(localStorage.key(i))) {
                            captcha = base.getStorage(localStorage.key(i));
                        }
                    }
                    let deviceid = /(\w{32})/.exec(base.getStorage('deviceid').split(','))[0];
                    let token = {
                        credentials,
                        captcha,
                        deviceid
                    };
                    return token;
                },

                async getFileUrlByOnce(item, index, token) {
                    try {
                        if (item.downloadUrl) return {
                            index,
                            downloadUrl: item.downloadUrl
                        };
                        let res = await base.get(pan.pcs[0] + item.id, {
                            'Authorization': `${token.credentials.token_type} ${token.credentials.access_token}`,
                            'content-type': "application/json",
                            'x-captcha-token': token.captcha.token,
                            'x-device-id': token.deviceid,
                        });
                        if (res.web_content_link) {
                            return {
                                index,
                                downloadUrl: res.web_content_link
                            };
                        } else {
                            return {
                                index,
                                downloadUrl: '获取下载地址失败,请刷新重试!'
                            };
                        }
                    } catch (e) {
                        return message.error('提示:请先登录网盘后刷新页面!');
                    }
                },

                async getPCSLink() {
                    selectList = this.getSelectedList();
                    if (selectList.length === 0) {
                        return message.error('提示:请先勾选要下载的文件!');
                    }
                    if (this.isOnlyFolder()) {
                        return message.error('提示:请打开文件夹后勾选文件!');
                    }
                    if (pt === 'home') {
                        let queue = [];
                        let token = this.getToken();
                        selectList.forEach((item, index) => {
                            queue.push(this.getFileUrlByOnce(item, index, token));
                        });
                        const res = await Promise.all(queue);
                        res.forEach(val => {
                            selectList[val.index].downloadUrl = val.downloadUrl;
                        });
                    } else {
                        return message.error('提示:请转存到自己网盘后去网盘主页下载!');
                    }
                    let html = this.generateDom(selectList);
                    this.showMainDialog(pan[mode][0], html, pan[mode][1]);

                },

                generateDom(list) {
                    let content = '<div class="pl-main">';
                    let alinkAllText = '';
                    list.forEach((v, i) => {
                        if (v.kind === 'drive#folder') return;
                        let filename = v.name;
                        let size = base.sizeFormat(+v.size);
                        let dlink = v.downloadUrl;
                        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 listener-link-api" data-filename="${filename}" data-link="${dlink}" data-index="${i}">${dlink}</a>
                                <div class="pl-item-btn listener-link-api-btn" data-filename="${filename}">复制文件名</div>
                                </div>`;
                        }
                        if (mode === 'aria') {
                            let alink = this.convertLinkToAria(dlink, filename, navigator.userAgent);
                            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" 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 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, navigator.userAgent);
                            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" 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 listener-link-aria" href="${alink}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> </div>`;
                            }
                        }
                        if (mode === 'bc') {
                            let alink = this.convertLinkToBC(dlink, filename, navigator.userAgent);
                            content += `<div class="pl-item">
                                <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                                <a class="pl-item-link" href="${decodeURIComponent(alink)}" title="点击用比特彗星下载" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> 
                                <div class="pl-item-btn listener-link-bc-btn" data-dlink="${dlink}">复制镜像地址</div>
                                </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 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: []
                        }]
                    };
                    try {
                        let res = await base.post(url, rpcData, {}, '');
                        if (res.result) return 'success';
                        return 'fail';
                    } catch (e) {
                        return 'fail';
                    }
                },

                getSelectedList() {
                    try {
                        let doms = document.querySelectorAll('.pan-list-item');
                        let selectedList = [];
                        for (let dom of doms) {
                            let domVue = dom.__vue__;
                            if (domVue.selected.includes(domVue.info.id)) {
                                selectedList.push(domVue.info);
                            }
                        }
                        return selectedList;
                    } catch (e) {
                        return [];
                    }
                },

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

                isOnlyFolder() {
                    for (let i = 0; i < selectList.length; i++) {
                        if (selectList[i].kind === 'drive#file') return false;
                    }
                    return true;
                },

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

                async initPanLinker() {
                    base.initDefaultConfig();
                    base.addPanLinkerStyle();
                    pt = this.detectPage();
                    let res = await base.post
                    (`https://api.youxiaohou.com/config/xunlei?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();
                }
            };

            let quark = {

                convertLinkToAria(link, filename, ua) {
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`aria2c "${link}" --out "${filename}" --header "Cookie: ${document.cookie}"`);
                },

                convertLinkToBC(link, filename, ua) {
                    let bc = `AA/${encodeURIComponent(filename)}/?url=${encodeURIComponent(link)}&cookie=${encodeURIComponent(document.cookie)}ZZ`;
                    return encodeURIComponent(`bc://http/${base.e(bc)}`);
                },

                convertLinkToCurl(link, filename, ua) {
                    let terminal = base.getValue('setting_terminal_type');
                    filename = filename.replace(' ', '_');
                    return encodeURIComponent(`${terminal !== 'wp' ? 'curl' : 'curl.exe'} -L "${link}" --output "${filename}" -b "${document.cookie}"`);
                },

                addPageListener() {
                    window.addEventListener('hashchange', (event) => {
                        pan.num === base.getValue('setting_init_code') ? this.addButton() : this.addInitButton();

                    });
                    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();
                        $('#downloadIframe').attr('src', e.currentTarget.dataset.link);
                    });
                    doc.on('click', '.listener-link-aria, .listener-copy-all', (e) => {
                        e.preventDefault();
                        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 {
                            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});
                    });
                },

                addButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="quark-button pl-button"><svg width="22" height="22" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd" stroke="#555" stroke-width="2"><path stroke-linecap="round" stroke-linejoin="round" d="M9 12l2 2 2-2z"/><path d="M14 8h1.553c.85 0 1.16.093 1.47.267.311.174.556.43.722.756.166.326.255.65.255 1.54v4.873c0 .892-.089 1.215-.255 1.54-.166.327-.41.583-.722.757-.31.174-.62.267-1.47.267H6.447c-.85 0-1.16-.093-1.47-.267a1.778 1.778 0 01-.722-.756c-.166-.326-.255-.65-.255-1.54v-4.873c0-.892.089-1.215.255-1.54.166-.327.41-.583.722-.757.31-.174.62-.267 1.47-.267H11"/><path stroke-linecap="round" stroke-linejoin="round" d="M11 3v10"/></g></svg> 下载助手<ul class="pl-dropdown-menu"><li class="pl-dropdown-menu-item pl-button-mode" data-mode="api">API下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="aria" >Aria下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="rpc">RPC下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="curl">cURL下载</li><li class="pl-dropdown-menu-item pl-button-mode" data-mode="bc" >BC下载</li>${pan.code == 200 && version < pan.version ? pan.new : ''}</ul></div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                },

                addInitButton() {
                    if (!pt) return;
                    let $toolWrap;
                    let $button = $(`<div class="quark-button pl-button-init"><svg width="22" height="22" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd" stroke="#555" stroke-width="2"><path stroke-linecap="round" stroke-linejoin="round" d="M9 12l2 2 2-2z"/><path d="M14 8h1.553c.85 0 1.16.093 1.47.267.311.174.556.43.722.756.166.326.255.65.255 1.54v4.873c0 .892-.089 1.215-.255 1.54-.166.327-.41.583-.722.757-.31.174-.62.267-1.47.267H6.447c-.85 0-1.16-.093-1.47-.267a1.778 1.778 0 01-.722-.756c-.166-.326-.255-.65-.255-1.54v-4.873c0-.892.089-1.215.255-1.54.166-.327.41-.583.722-.757.31-.174.62-.267 1.47-.267H11"/><path stroke-linecap="round" stroke-linejoin="round" d="M11 3v10"/></g></svg> 下载助手</div>`);
                    if (pt === 'home') {
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.home);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    if (pt === 'share') {
                        $button.css({'margin-right': '10px'});
                        let ins = setInterval(() => {
                            $toolWrap = $(pan.btn.share);
                            if ($toolWrap.length > 0) {
                                $toolWrap.prepend($button);
                                clearInterval(ins);
                            }
                        }, 50);
                    }
                    $button.click(() => base.initDialog());
                },

                async getPCSLink() {
                    selectList = this.getSelectedList();
                    if (selectList.length === 0) {
                        return message.error('提示:请先勾选要下载的文件!');
                    }
                    if (this.isOnlyFolder()) {
                        return message.error('提示:请打开文件夹后勾选文件!');
                    }
                    let fids = [];
                    selectList.forEach(val => {
                        fids.push(val.fid);
                    });
                    if (pt === 'home') {
                        let res = await base.post(pan.pcs[0], {
                            "fids": fids
                        }, {"content-type": "application/json;charset=utf-8"});
                        if (res.code === 31001) {
                            return message.error('提示:请先登录网盘!');
                        }
                        if (res.code !== 0) {
                            return message.error('提示:获取链接失败!');
                        }
                        let html = this.generateDom(res.data);
                        this.showMainDialog(pan[mode][0], html, pan[mode][1]);
                    } else {
                        return message.error('提示:请转存到自己网盘后去网盘主页下载!');
                    }
                },

                generateDom(list) {
                    let content = '<div class="pl-main">';
                    let alinkAllText = '';
                    list.forEach((v, i) => {
                        if (v.file === false) return;
                        let filename = v.file_name;
                        let fid = v.fid;
                        let size = base.sizeFormat(v.size);
                        let dlink = v.download_url;
                        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 listener-link-api" data-fid="${fid}" data-filename="${filename}" data-link="${dlink}" data-index="${i}">${dlink}</a>
                                </div>`;
                        }
                        if (mode === 'aria') {
                            let alink = this.convertLinkToAria(dlink, filename, navigator.userAgent);
                            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" 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 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, navigator.userAgent);
                            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" 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 listener-link-aria" href="${alink}" title="点击复制curl链接" data-filename="${filename}" data-link="${alink}">${decodeURIComponent(alink)}</a> </div>`;
                            }
                        }
                        if (mode === 'bc') {
                            let alink = this.convertLinkToBC(dlink, filename, navigator.userAgent);
                            content += `<div class="pl-item">
                                <div class="pl-item-name listener-tip" data-size="${size}">${filename}</div>
                                <a class="pl-item-link" href="${decodeURIComponent(alink)}" title="点击用比特彗星下载" 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 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: [`Cookie: ${document.cookie}`]
                        }]
                    };
                    try {
                        let res = await base.post(url, rpcData, {"Cookie": document.cookie}, '');
                        if (res.result) return 'success';
                        return 'fail';
                    } catch (e) {
                        return 'fail';
                    }
                },

                getSelectedList() {
                    try {
                        let selectedList = [];
                        let reactDom = document.getElementsByClassName('file-list')[0];
                        let reactObj = base.findReact(reactDom);
                        let props = reactObj.props;
                        if (props) {
                            let fileList = props.list || [];
                            let selectedKeys = props.selectedRowKeys || [];
                            fileList.forEach((val) => {
                                if (selectedKeys.includes(val.fid)) {
                                    selectedList.push(val);
                                }
                            });
                        }
                        return selectedList;
                    } catch (e) {
                        return [];
                    }
                },

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

                isOnlyFolder() {
                    for (let i = 0; i < selectList.length; i++) {
                        if (selectList[i].file) return false;
                    }
                    return true;
                },

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

                async initPanLinker() {
                    base.initDefaultConfig();
                    base.addPanLinkerStyle();
                    pt = this.detectPage();
                    let res = await base.post
                    (`https://api.youxiaohou.com/config/quark?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();
                    this.addPageListener();
                    base.createTip();
                    base.createDownloadIframe();
                    base.registerMenuCommand();
                }
            };

            let main = {
                init() {
                    if (/(pan|yun).baidu.com/.test(location.host)) {
                        baidu.initPanLinker();
                    }
                    if (/www.aliyundrive.com/.test(location.host)) {
                        ali.initPanLinker();
                    }
                    if (/cloud.189.cn/.test(location.host)) {
                        tianyi.initPanLinker();
                    }
                    if (/pan.xunlei.com/.test(location.host)) {
                        xunlei.initPanLinker();
                    }
                    if (/pan.quark.cn/.test(location.host)) {
                        quark.initPanLinker();
                    }
                }
            };

            main.init();
        })();
    }
})();