Greasy Fork is available in English.

万能工具箱-(2019.11.06修复百度网盘)

这是一个万能工具箱,我们的目标是你能用到的,这里都有!欢迎提交问题!目前已支持网页图片一键打包下载,爱奇艺腾讯等视频网站的VIP视频解析,QQ音乐、网易音乐等音乐网站的音乐解析下载,屏蔽百度搜索广告,闲鱼搜索框,自动查找百度提取码,知乎视频下载,百度网盘下载,接触右键限制,百度文库解析下载,网页图片预览

// ==UserScript==
// @name         万能工具箱-(2019.11.06修复百度网盘)
// @namespace    http://www.ganfl.com/
// @connect api.ganfl.com
// @connect api.iquan.wang
// @connect tm.iquan.wang
// @connect taobao.com
// @version      4.6
// @description  这是一个万能工具箱,我们的目标是你能用到的,这里都有!欢迎提交问题!目前已支持网页图片一键打包下载,爱奇艺腾讯等视频网站的VIP视频解析,QQ音乐、网易音乐等音乐网站的音乐解析下载,屏蔽百度搜索广告,闲鱼搜索框,自动查找百度提取码,知乎视频下载,百度网盘下载,接触右键限制,百度文库解析下载,网页图片预览
// @author       xavier_dev
// @require      https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js
// @require      https://cdn.bootcss.com/layer/2.3/layer.js
// @require      https://cdn.bootcss.com/echarts/4.2.1/echarts.min.js
// @require     https://cdn.bootcss.com/jszip/3.1.5/jszip.min.js
// @grant  GM_xmlhttpRequest
// @grant       GM_info
// @grant       GM.getValue
// @grant    GM.setValue
// @grant    GM_getValue
// @grant    GM_setValue
// @grant    GM_notification
// @grant    GM.registerMenuCommand
// @grant    GM.openInTab
// @grant    GM_openInTab
// @grant    GM_registerMenuCommand
// @connect *

// @match        *://*/*
// ==/UserScript==

(function () {
    'use strict';
    var localHref = window.location.href, disable_contextmenu = false, mouse_right_panel = null, img_src = null,
        asyncGMAPI = false, getValue, last_update = 0;
    var default_setting = {
        "setting_funs": [
            {"id": "tmsetting_showLeftMenu", "mc": "显示左侧侧边栏功能菜单", "checked": "checked"},
            {"id": "tmsetting_bdlads", "mc": "屏蔽百度搜索收尾推广", "checked": "checked"},
            {"id": "tmsetting_bdrads", "mc": "屏蔽百度搜索右侧广告", "checked": "checked"},
            // {"id":"tmsetting_bdbjhads","mc":"屏蔽百度搜索百家号"},
            // {"id": "tmsetting_bdpan", "mc": "自动验证百度网盘链接有效性"},
            {"id": "tmsetting_bdpantqm", "mc": "自动查找百度网盘提取码", "checked": "checked"},
            {"id": "tmsetting_bdpantqmfx", "mc": "自动分享百度网盘提取码", "checked": "checked"},
            // {"id": "tmsetting_taobaoxianyu", "mc": "显示淘宝闲鱼搜索框", "checked": ""},
            {"id": "tmsetting_wangpandown", "mc": "显示百度网盘下载助手", "checked": "checked"},
            {"id": "tmsetting_imgziptitle", "mc": "图片打包下载以网页标题作为文件名", "checked": "checked"},
            {"id": "tmsetting_ads", "mc": "关闭脚本的广告推送", "checked": "checked"},
            {"id": "tmsetting_iframe", "mc": "否仅在顶层页面(框架)运行", "checked": "checked"},
            {"id": "tmsetting_mouse", "mc": "解除网页右键限制,开启后无法运行划词翻译", "checked": "checked"}
        ],
        "menuHot_key": "ctrlKey",
        "menuopacity": "1",
        "searchImageSite_list": {
            "Baidu": "https://image.baidu.com/n/pc_search?queryImageUrl={%s}&fm=result_camera&uptype=paste&drag=1",
            "360 ShiTu": "http://st.so.com/stu?imgurl={%s}",
            "TaoBao": "https://ascii2d.net/search/url/{%s}"
        },
        "menu_funs": [
            {"id": "tm_gjx_vipjx", "mc": "VIP视频免费播放"},
            {"id": "tm_gjx_musicjx", "mc": "音乐免费下载播放"},
            {"id": "tm_gjx_img_down", "mc": "下载本页所有图片"},
            {"id": "tm_gjx_showallimg", "mc": "查看本页图片"}
        ],
        "menu_funs_regex":[
            {"id": "tm_gjx_zhihu_video", "mc": "解析本页知乎视频","re":"zhihu.com"},
            {"id":"tm_gjx_wenkujx","mc":"文库解析","re":"wenku.baidu.com/view"}
            //  ,{"id":"tm_gjx_hsjx","mc":"视频解析","re":"(yaoshe)|(yuese)|(furryplace)"}
        ],
        "searchImageSite_option": ["Baidu", "360 ShiTu", "TaoBao"],
        "videoApiUrl": "http://jx.51yfx.com/?url=",
        "musicApiUrl": "http://music.51yfx.com/?type=yh&url=",
        "zhihuApiUrl": "https://tm.iquan.wang/api/v1/",
        "baseApiUrl": "http://api.ganfl.com/",
        "baiduPanApiUrl": "http://api.iquan.wang/test/",
        "suffix": "jpg",
        "downPicMinWidth": 200,
        "last_version": 2.7
    }
    //将脚本排除代码单独定义, 避免恢复默认设置后 被清空
    var ruleSite=[];
    var setting = null;

    pageInit();
    onUpdateAfter();
    if (get_setting_funs_value('tmsetting_showLeftMenu') == "checked") {
        var isAddMenu=true;
        for(var i in ruleSite){
            var reg =new RegExp(ruleSite[i]);
            if(reg.test(localHref)){
                isAddMenu=false;
                break;
            }
        }
        if(isAddMenu){
            addMenu();
        }else{ throw SyntaxError();}
    }

    function pageInit() {
        setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
        ruleSite = GM_getValue('tmgjx_ruleSite') ? GM_getValue('tmgjx_ruleSite') : ruleSite;
        if (setting.last_version != default_setting.last_version) {
            var user_setting_funs = setting.setting_funs;
            var def_settng_funs = default_setting.setting_funs;
            setting = default_setting;
            for (var i in def_settng_funs) {
                var defFunsId = def_settng_funs[i].id;
                var existsFuns = false;
                for (var j in user_setting_funs) {
                    var userFunsId = user_setting_funs[j].id;
                    if (defFunsId === userFunsId) {
                        existsFuns = true;
                        break;
                    }
                    //删除闲鱼搜索框功能
                    if(userFunsId=='tmsetting_taobaoxianyu'){
                        user_setting_funs.splice(j);
                    }
                }
                if(!existsFuns){
                    user_setting_funs.push(def_settng_funs[i]);
                }
            }
            setting.setting_funs=user_setting_funs;

            set_setting(setting);
        }

        if (typeof GM_getValue === 'undefined' && typeof GM !== 'undefined') {
            self.GM_getValue = GM.getValue;
            self.GM_setValue = GM.setValue;
            self.GM_openInTab = GM.openInTab;
            self.GM_registerMenuCommand = GM.registerMenuCommand;
            getValue = GM.getValue;
            asyncGMAPI = true;
        } else {
            getValue = function (key, init) {
                return new Promise(function (resolve, reject) {
                    try {
                        resolve(GM_getValue(key, init));
                    } catch (e) {
                        reject(e);
                    }
                });
            };
        }
        //先判断是否在iframe里面
        if (self != top&&get_setting_funs_value('tmsetting_iframe') == "checked") {
            throw SyntaxError();
        }
        $("body").append($('<link href="https://cdn.bootcss.com/layer/2.3/skin/layer.css" rel="stylesheet">'));
        addStyle(".tm_gjx_box{margin: 40px 0;position: fixed;top:200px;z-index:99999;} .tm_gjx_change-type { min-width: 40px; min-height: 160px; position: absolute; z-index: 99; left: 0; top: 0; display: flex; } .tm_gjx_change-type .tm_gjx_type-left { width: 0; background: #fff; height: 100%; box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.5); border-bottom-right-radius: 5px; overflow: hidden; transition: width 0.4s; -moz-transition: width 0.4s; -webkit-transition: width 0.4s; -o-transition: width 0.4s; } .tm_gjx_change-type .tm_gjx_showListType { width: 130px; transition: width 0.4s; -moz-transition: width 0.4s; -webkit-transition: width 0.4s; -o-transition: width 0.4s; } .tm_gjx_change-type .tm_gjx_type-left ul li { line-height: 40px; height: 40px; text-align: left; width: 100%; position: relative; cursor: pointer; } .tm_gjx_change-type .tm_gjx_type-left ul li a { display: block; height: 100%; position: absolute; left: 0; top: 0; z-index: 9; padding-left: 15px; overflow: hidden; width: calc(100% - 17px); color: #333; font-size: 14px; border-left: 2px solid #26778d; /*#26778d 00ba97 */ } .tm_gjx_change-type .tm_gjx_type-left ul li span { display: block; position: absolute; width: 0; height: 100%; left: 0; top: 0; z-index: 8; overflow: hidden; transition: width 0.5s; -moz-transition: width 0.5s; -webkit-transition: width 0.5s; -o-transition: width 0.5s; } .tm_gjx_change-type .tm_gjx_type-left ul li:hover span { transition: width 0.5s; -moz-transition: width 0.5s; -webkit-transition: width 0.5s; -o-transition: width 0.5s; } .tm_gjx_type-left ul li:nth-child(1):hover span, .tm_gjx_type-left ul li:nth-child(1).active span, .tm_gjx_type-left ul li:nth-child(8):hover span, .tm_gjx_type-left ul li:nth-child(8).active span { background: #ad1457; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(1):hover a, .tm_gjx_type-left ul li:nth-child(1).active a, .tm_gjx_type-left ul li:nth-child(8):hover a, .tm_gjx_type-left ul li:nth-child(8).active a { border-left: 2px solid #ad1457; color: #fff; } .tm_gjx_type-left ul li:nth-child(2):hover span, .tm_gjx_type-left ul li:nth-child(2).active span, .tm_gjx_type-left ul li:nth-child(9):hover span, .tm_gjx_type-left ul li:nth-child(9).active span { background: #1976d2; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(2):hover a, .tm_gjx_type-left ul li:nth-child(2).active a, .tm_gjx_type-left ul li:nth-child(9):hover a, .tm_gjx_type-left ul li:nth-child(9).active a { border-left: 2px solid #1976d2; color: #fff; } .tm_gjx_type-left ul li:nth-child(3):hover span, .tm_gjx_type-left ul li:nth-child(3).active span, .tm_gjx_type-left ul li:nth-child(10):hover span, .tm_gjx_type-left ul li:nth-child(10).active span { background: #ef5350; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(3):hover a, .tm_gjx_type-left ul li:nth-child(3).active a, .tm_gjx_type-left ul li:nth-child(10):hover a, .tm_gjx_type-left ul li:nth-child(10).active a { border-left: 2px solid #ef5350; color: #fff; } .tm_gjx_type-left ul li:nth-child(4):hover span, .tm_gjx_type-left ul li:nth-child(4).active span, .tm_gjx_type-left ul li:nth-child(11):hover span, .tm_gjx_type-left ul li:nth-child(11).active span { background: #e91e63; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(4):hover a, .tm_gjx_type-left ul li:nth-child(4).active a, .tm_gjx_type-left ul li:nth-child(11):hover a, .tm_gjx_type-left ul li:nth-child(11).active a { border-left: 2px solid #e91e63; color: #fff; } .tm_gjx_type-left ul li:nth-child(5):hover span, .tm_gjx_type-left ul li:nth-child(5).active span, .tm_gjx_type-left ul li:nth-child(12):hover span, .tm_gjx_type-left ul li:nth-child(12).active span { background: #8e24aa; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(5):hover a, .tm_gjx_type-left ul li:nth-child(5).active a, .tm_gjx_type-left ul li:nth-child(12):hover a, .tm_gjx_type-left ul li:nth-child(12).active a { border-left: 2px solid #8e24aa; color: #fff; } .tm_gjx_type-left ul li:nth-child(6):hover span, .tm_gjx_type-left ul li:nth-child(6).active span, .tm_gjx_type-left ul li:nth-child(13):hover span, .tm_gjx_type-left ul li:nth-child(13).active span { background: #64b5f6; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(6):hover a, .tm_gjx_type-left ul li:nth-child(6).active a, .tm_gjx_type-left ul li:nth-child(13):hover a, .tm_gjx_type-left ul li:nth-child(13).active a { border-left: 2px solid #64b5f6; color: #fff; } .tm_gjx_type-left ul li:nth-child(7):hover span, .tm_gjx_type-left ul li:nth-child(7).active span, .tm_gjx_type-left ul li:nth-child(14):hover span, .tm_gjx_type-left ul li:nth-child(14).active span { background: #388e3c; width: 100%; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); } .tm_gjx_type-left ul li:nth-child(7):hover a, .tm_gjx_type-left ul li:nth-child(7).active a, .tm_gjx_type-left ul li:nth-child(14):hover a, .tm_gjx_type-left ul li:nth-child(14).active a { border-left: 2px solid #388e3c; color: #fff; } .tm_gjx_change-type .tm_gjx_type-right {opacity:" + setting.menuopacity + ";width: 25px; background: #62778d; height: 150px; overflow: hidden; box-shadow: 0px 2px 5px 0 rgba(0, 0, 0, 0.5); border-top-right-radius: 5px; border-bottom-right-radius: 5px; display: table; } .tm_gjx_change-type .tm_gjx_type-right p { text-align: center; padding: 0 5px; color: #fff; display: table-cell; vertical-align: middle; cursor: pointer; line-height: 20px; } .tm_gjx_type-left ul,tm_gjx_type-left li{margin:0;padding:0;list-style:none;}");
        addStyle('.mg15{margin: 15px;text-align:left;} .setting_lab{line-height: 30px;} .tpl-switch{float:right} .tpl-switch input[type="checkbox"] { position: absolute; opacity: 0; width:50px; height:25px; } .tpl-switch input[type="checkbox"].ios-switch+div { vertical-align: middle; width: 40px; height: 20px; border-radius: 999px; background-color: rgba(0, 0, 0, 0.1); -webkit-transition-duration: .4s; -webkit-transition-property: background-color, box-shadow; margin-top: 6px; } .tpl-switch input[type="checkbox"].ios-switch:checked+div { width: 40px; background-position: 0 0; background-color: #36c6d3; } .tpl-switch input[type="checkbox"].tinyswitch.ios-switch+div { width: 34px; height: 18px; } .tpl-switch input[type="checkbox"].bigswitch.ios-switch+div { width: 50px; height: 25px; } .tpl-switch input[type="checkbox"].green.ios-switch:checked+div { background-color: #00e359; border: 1px solid rgba(0, 162, 63, 1); box-shadow: inset 0 0 0 10px rgba(0, 227, 89, 1); } .tpl-switch input[type="checkbox"].ios-switch+div>div { float: left; width: 18px; height: 18px; border-radius: inherit; background: #ffffff; -webkit-transition-timing-function: cubic-bezier(.54, 1.85, .5, 1); -webkit-transition-duration: 0.4s; -webkit-transition-property: transform, background-color, box-shadow; -moz-transition-timing-function: cubic-bezier(.54, 1.85, .5, 1); -moz-transition-duration: 0.4s; -moz-transition-property: transform, background-color; pointer-events: none; margin-top: 1px; margin-left: 1px; } .tpl-switch input[type="checkbox"].ios-switch:checked+div>div { -webkit-transform: translate3d(20px, 0, 0); -moz-transform: translate3d(20px, 0, 0); background-color: #ffffff; } .tpl-switch input[type="checkbox"].tinyswitch.ios-switch+div>div { width: 16px; height: 16px; margin-top: 1px; } .tpl-switch input[type="checkbox"].tinyswitch.ios-switch:checked+div>div { -webkit-transform: translate3d(16px, 0, 0); -moz-transform: translate3d(16px, 0, 0); box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.3), 0px 0px 0 1px rgba(8, 80, 172, 1); } .tpl-switch input[type="checkbox"].bigswitch.ios-switch+div>div { width: 23px; height: 23px; margin-top: 1px; } .tpl-switch input[type="checkbox"].bigswitch.ios-switch:checked+div>div { -webkit-transform: translate3d(25px, 0, 0); -moz-transform: translate3d(16px, 0, 0); } .tpl-switch input[type="checkbox"].green.ios-switch:checked+div>div { box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(0, 162, 63, 1); }');
        addStyle('.layer_notice{float:left;color:white; width:330px;font-size:14px;  overflow:hidden;  background:#5FB878; padding:10px;};.layui-btn{margin:5px 1px;display: inline-block; height: 38px; line-height: 38px; padding: 0 18px; background-color: #009688; color: #fff; white-space: nowrap; text-align: center; font-size: 14px; border: none; border-radius: 30px; cursor: pointer}')
        if(get_setting_funs_value('tmsetting_ads') == "checked"){
            var checkTs = GM_getValue('setRightAdsTime');
            var now = $.now();
            if (checkTs > now) {
                //todo
            } else {
                GM_xmlhttpRequest({
                    method: "GET", url: "http://api.ganfl.com/test/yhhd",
                    onload: function (res) {
                        res = JSON.parse(res.responseText);
                        console.info(res)
                        if (res.status == 1&&res.data!=null) {
                            var ads = '<section class="ch1 doudong"> <a href="javascript:void(0)" data-cat="tmall1111" data-url="' + res.data.url + '" target="_blank" title="' + res.data.title + '"><img src="' + res.data.icon + '" ></a><a  data-cat="hidead" class="btn-close"></a></section>';
                            $("body").append(ads)
                        }
                    }
                });
                addStyle('/*双11*/ @-moz-keyframes tada{ /*0%{-moz-transform:scale(1);}*/ 10%,20%{-moz-transform: rotate(-3deg);} 30%,50%,70%,90%{-moz-transform: rotate(3deg);} 40%,60%,80%{-moz-transform: rotate(-3deg);} 100%{-moz-transform: rotate(0);} } @-webkit-keyframes tada{ /* 0%{-webkit-transform:scale(1);}*/ 10%,20%{-webkit-transform: rotate(-3deg);} 30%,50%,70%,90%{-webkit-transform: rotate(3deg);} 40%,60%,80%{-webkit-transform: rotate(-3deg);} 100%{-webkit-transform: rotate(0);}}.doudong{ -webkit-animation: tada 2.4s linear infinite; -moz-animation: tada 2.4s linear infinite; } .doudong:hover{ -webkit-animation: 2.4s linear infinite; -moz-animation: 2.4s linear infinite; } /*侧滑 1s .2s ease both*/ .ch1 { display: block; position: fixed; width: 50px; z-index: 999; right: 5%; bottom: 5%; } .ch1 img{ width: 90px; max-width:250px; } .ch1 a { display: inline-block; } .animate-bounce-up{ -webkit-animation: bounce-up 1s linear infinite;animation: bounce-up 1s linear infinite;} .btn-close{ position: absolute; right: -60px; bottom: 90px; width: 32px; height: 32px; z-index: 4; background: url(../images/btn-close.png) center center no-repeat; cursor: pointer; } .doudong{ -webkit-animation: tada 2.4s linear infinite; -moz-animation: tada 2.4s linear infinite; } .doudong:hover{ -webkit-animation: 2.4s linear infinite; -moz-animation: 2.4s linear infinite; } /*侧滑 1s .2s ease both*/ .ch1 { display: block; position: fixed; width: 50px; z-index: 999; right: 5%; bottom: 5%; } .ch1 img{ width: 90px; max-width:250px; } .ch1 a { display: inline-block; } .animate-bounce-up{ -webkit-animation: bounce-up 1s linear infinite;animation: bounce-up 1s linear infinite;} .btn-close{ position: absolute; right: -60px; bottom: 90px; width: 32px; height: 32px; z-index: 4; background: url() center center no-repeat; cursor: pointer; }');
            }
        }
    }
    function onUpdateAfter() {
        if(GM_info.script.version!=GM_getValue('tm_version')){
            $("body").after(" <ul class=\"layer_notice\" >\n" +
                "    <li>本次更新内容:</li>\n" +
                "    <li>1.修复百度网盘高速下载</li>\n" +
                "  </ul>\n");
            layer.open({
                type: 1,
                shade: false,
                title: false,
                content: $('.layer_notice'),
                cancel: function(){
                    GM_setValue("tm_version",GM_info.script.version);
                }
            });
        }
    }
    //添加设置菜单
    function addMenu() {
        var menuSetting = "";
        for (var i = 0; i < default_setting.menu_funs.length; i++) {
            menuSetting += '<li><a data-cat=' + default_setting.menu_funs[i].id + '>' + default_setting.menu_funs[i].mc + '</a><span></span></li> ';
        }
        for (var i = 0; i < default_setting.menu_funs_regex.length; i++) {
            var reg =new RegExp(default_setting.menu_funs_regex[i].re);
            if(reg.test(localHref)){
                menuSetting += '<li><a data-cat=' + default_setting.menu_funs_regex[i].id + '>' + default_setting.menu_funs_regex[i].mc + '</a><span></span></li> ';
            }
        }

        var sidenav = '<div class="tm_gjx_box"> <div class="tm_gjx_change-type"> <div class="tm_gjx_type-left" class="tm_gjx_showListType"> <ul> ' +
            menuSetting +
            '<li><a data-cat=tm_gjx_setting>设置</a><span></span></li> ' +
            '<li><a data-cat=tm_gjx_help>帮助</a><span></span></li> ' +
            '</ul> </div> <div class="tm_gjx_type-right"> <p> <i class="tm_gjx_el-icon-menu"></i> 功能选择 </p> </div> </div> </div>';
        $("body").append(sidenav);

        $('.tm_gjx_type-right').click(function () {
            $(this).prev('.tm_gjx_type-left').toggleClass('tm_gjx_showListType')
        });
        $('.tm_gjx_type-left ul li').click(function () {
            $(this).addClass('tm_gjx_active').siblings('li').removeClass('tm_gjx_active')
        })
    }

    document.addEventListener('mousedown', function (event) {
        if (disable_contextmenu == true) {
            document.oncontextmenu = null;
            disable_contextmenu = false;
        }
        if (event[setting.menuHot_key] == true && event.button == 2) {
            if (mouse_right_panel == null) create_panel();
            // GM 4.x api is async, so we cannot update it in time
            else {
                if (!asyncGMAPI) {
                    if (last_update != GM_getValue('timestamp', 0)) {
                        last_update = GM_getValue('timestamp', 0);
                        mouse_right_panel.parentElement && mouse_right_panel.parentElement.removeChild(mouse_right_panel);
                        setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
                        create_panel();
                    } else document.body.appendChild(mouse_right_panel);
                } else {
                    document.body.appendChild(mouse_right_panel);
                    mouse_right_panel.parentElement && mouse_right_panel.parentElement.removeChild(mouse_right_panel);
                    setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
                }
            }
            mouse_right_panel.style.left = (document.documentElement.offsetWidth + (document.documentElement.scrollLeft || document.body.scrollLeft) - event.pageX >= 200 ? event.pageX : event.pageX >= 200 ? event.pageX - 200 : 0) + 'px';
            mouse_right_panel.style.top = (event.pageY + mouse_right_panel.offsetHeight < (document.documentElement.scrollTop || document.body.scrollTop) + document.documentElement.clientHeight ? event.pageY : event.pageY >= mouse_right_panel.scrollHeight ? event.pageY - mouse_right_panel.offsetHeight : 0) + 'px';
            disable_contextmenu = true;
            document.oncontextmenu = function () {
                return false;
            };
            if (event.target.tagName.toLowerCase() == 'img' && event.target.src != null) {
                mouse_right_panel.getElementsByClassName('search_top_url')[0].style.marginTop = '0px';
                mouse_right_panel.getElementsByClassName('search_top_url')[0].textContent = event.target.src;
                if (/^data:\s*.*?;\s*base64,\s*/.test(event.target.src)) upload_file(event.target.src);
                else if (/^(?:blob:|filesystem:)/.test(event.target.src)) upload_blob_url(event.target.src);
                else img_src = event.target.src;
            } else {
                mouse_right_panel.getElementsByClassName('search_top_url')[0].style.marginTop = '-24px';
                var firefoxPasteNode = document.getElementsByClassName('image-search-paste-node-firefox')[0];
                if (navigator.userAgent.indexOf('Firefox') >= 0 && firefoxPasteNode) {
                    firefoxPasteNode.innerHTML = '';
                    firefoxPasteNode.focus();
                } else document.addEventListener('paste', get_clipboard, false);
            }
        } else if (mouse_right_panel != null) {
            if (event.target.compareDocumentPosition(mouse_right_panel) == 10 || event.target.compareDocumentPosition(mouse_right_panel) == 0) {
                if (event.target.className == 'image-search-item' && event.button == 0) {
                    switch (event.target.getAttribute('search-option')) {
                        case 'all':
                            if (img_src != null) {
                                for (var i = setting.site_option.length - 1; i >= 0; i--) {
                                    var rsrc = img_src;
                                    var turl = setting.site_list[setting.site_option[i]];
                                    if (turl.substr(0, turl.indexOf('{%s}')).indexOf('?') >= 0) {
                                        rsrc = encodeURIComponent(img_src);
                                    }
                                    GM_openInTab(turl.replace(/\{%s\}/, rsrc), event[setting.hot_key]);
                                }
                                hide_panel();
                            }
                            break;
                        default:
                            if (img_src != null) {
                                var rsrc = img_src;
                                var turl = setting.site_list[event.target.getAttribute('search-option')];
                                if (turl.substr(0, turl.indexOf('{%s}')).indexOf('?') >= 0) {
                                    rsrc = encodeURIComponent(img_src);
                                }

                                GM_openInTab(turl.replace(/\{%s\}/, rsrc), event[setting.hot_key]);
                                hide_panel();
                            }
                    }
                } else if (event.button != 0) hide_panel();
            } else hide_panel();
        }
    }, true);

    function hide_panel() {
        if (!mouse_right_panel || !mouse_right_panel.parentElement) return;
        img_src = null;
        mouse_right_panel.parentElement && mouse_right_panel.parentElement.removeChild(mouse_right_panel);
        document.removeEventListener('paste', get_clipboard, false);
    }

    function get_clipboard(event) {
        var items = event.clipboardData.items;
        if (items[items.length - 1].type.indexOf('image') >= 0) reader.readAsDataURL(items[items.length - 1].getAsFile());
    }

    function create_panel() {
        mouse_right_panel = document.createElement('div');
        mouse_right_panel.style.cssText = 'width: 198px; font-size: 14px; text-align: center; position: absolute; color: #000; z-index: 9999999999; box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.5); border: 1px solid #CCC; background: rgba(255, 255, 255, 0.9); border-top-right-radius: 2px; border-bottom-left-radius: 2px; font-family: "Arial"; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none;';
        document.body.appendChild(mouse_right_panel);
        var search_top = document.createElement('div');
        search_top.style.cssText = 'height: 24px; line-height: 24px; font-size: 12px; overflow: hidden; margin: 0 auto; padding: 0 5px;';
        search_top.className = 'image-search-top';
        search_top.innerHTML = '<div class="search_top_url" style="overflow: hidden; white-space: nowrap; text-overflow: ellipsis; width: 100%; height: 24px;"></div><div class="search_top_file" style="width: 100%; height: 24px; line-height: 24px;" draggable="true"><label for="image-search-file">本菜单由万能工具箱提供</label></div><style>.image-search-item{color: #000000; transition: all 0.2s linear; -webkit-transition: all 0.1s linear;}.image-search-item:hover{background: #eeeeee;}</style>';
        mouse_right_panel.appendChild(search_top);
        var search_item = document.createElement('div');
        search_item.style.cssText = 'width: 100%; height: 24px; line-height: 24px; cursor: pointer;';
        search_item.className = 'image-search-item';
        for (var i in default_setting.menu_funs) {
            var search_item_child = search_item.cloneNode(true);
            search_item_child.textContent = default_setting.menu_funs[i].mc;
            search_item_child.setAttribute('data-cat', default_setting.menu_funs[i].id);
            mouse_right_panel.appendChild(search_item_child);
        }
        for (var i = 0; i < default_setting.menu_funs_regex.length; i++) {
            var reg =new RegExp(default_setting.menu_funs_regex[i].re);
            if(reg.test(localHref)){
                var search_item_child = search_item.cloneNode(true);
                search_item_child.textContent = default_setting.menu_funs_regex[i].mc;
                search_item_child.setAttribute('data-cat', default_setting.menu_funs_regex[i].id);
                mouse_right_panel.appendChild(search_item_child);
            }
        }
        search_item.textContent = '设置';
        search_item.setAttribute('data-cat', 'tm_gjx_setting');
        mouse_right_panel.appendChild(search_item);
        mouse_right_panel.ondrop = function (event) {
            event.stopPropagation();
            event.preventDefault();
            var files = event.target.files || event.dataTransfer.files;
            if (files[files.length - 1].type.indexOf('image') >= 0) reader.readAsDataURL(files[files.length - 1]);
        };
        if (navigator.userAgent.indexOf('Firefox') >= 0) {
            var paste_node_firefox = document.createElement('div');
            paste_node_firefox.setAttribute('contenteditable', 'true');
            paste_node_firefox.className = 'image-search-paste-node-firefox';
            paste_node_firefox.style.cssText = 'width: 0!important; height: 0!important; position: absolute; overflow: hidden;';
            paste_node_firefox.addEventListener('paste', get_clipboard, false);
            search_top.appendChild(paste_node_firefox);
        }
    }
    function checkTs() {

        var checkTs = GM_getValue('checkTsTime');
        var now = $.now();
        if (checkTs > now) {
            //todo
        } else {
            var lasttsid = GM_getValue('lasttsid');
            if (lasttsid == 'undefined' || lasttsid === undefined) {
                lasttsid = 0;
            }
            GM_xmlhttpRequest({
                method: "GET", url: "http://api.ganfl.com/test/checkTs?id=" + lasttsid,
                onload: function (res) {
                    console.info(res)
                    res = JSON.parse(res.responseText);
                    if (res.status == 1) {
                        GM_setValue('lasttsid', res.data.id);
                        notifiy(res.data.title, res.data.text, res.data.icon, res.data.click_url)
                    }
                }
            });
            GM_setValue('checkTsTime', $.now() + 60 * 60 * 1000);//记录超时时间
        }
    }
    checkTs();
    $('body').on('click', '[data-cat=hidead]', function () {
        $(".doudong").hide();
        GM_setValue('setRightAdsTime', $.now() + 30 * 60 * 1000);//记录超时时间
    });
    $('body').on('click', '[data-cat=tm_gjx_setting]', function () {
        openSettingPage();
    });
    $('body').on('click', '[data-cat=tmall1111]', function () {
        var url = $(this).attr("data-url");
        window.open(url);
        $(".doudong").hide();
        GM_setValue('setRightAdsTime', new Date().getTime()+((24*60*60)-(new Date().getHours()*60*60+new Date().getMinutes()*60+new Date().getSeconds()))*1000);//记录超时时间
    });
    $('body').on('click', '[data-cat=tmgjx_setting]', function () {
        var id = $(this).attr("id");
        if(id=="tmsetting_ads"){
            if($(this).prop("checked")){
                layer.msg('已开启❤️❤️❤️🌹🌹🌹', {icon: 6});
            }else{
                layer.confirm('亲❤️,一定要关闭本功能吗?我仅仅在618的时候在右下角显示一个领红包的图标哟,并且每天只显示一次。', {
                    btn: ['一定要关闭💔️','算了,饶了你吧🌹‍'] //按钮
                }, function(){
                    for (var i in setting.setting_funs) {
                        if (setting.setting_funs[i].id == id) {
                            if ($(this).prop("checked")) {
                                setting.setting_funs[i].checked = "checked";
                            } else {
                                setting.setting_funs[i].checked = "";
                            }
                        }
                    };
                    layer.msg('已关闭💔💔💔', {icon: 5});
                }, function(){
                    layer.msg('O(∩_∩)O谢谢💖💖', {icon: 6});
                });
            }
        }else{
            for (var i in setting.setting_funs) {
                if (setting.setting_funs[i].id == id) {
                    if ($(this).prop("checked")) {
                        setting.setting_funs[i].checked = "checked";
                    } else {
                        setting.setting_funs[i].checked = "";
                    }
                }
            }
        }
        set_setting(setting);


    });
    $('body').on('click', '[data-cat=tm_gjx_vipjx]', function () {
        window.open(setting.videoApiUrl + localHref);
        try{hide_panel();}catch(e){}
    });
    $('body').on('click', '[data-cat=tm_gjx_618]', function () {
        window.open("http://www.ganfl.com/618/");
        try{hide_panel();}catch(e){}
    });
    $('body').on('click', '[data-cat=tm_gjx_zhihu_video]', function () {
        downZhiHuVideo();
        try{hide_panel();}catch(e){}
    });
    $('body').on('click', '[data-cat=tm_gjx_musicjx]', function () {
        window.open(setting.musicApiUrl + encodeURIComponent(localHref));
        try{hide_panel();}catch(e){}
    });
    $('body').on('click', '[data-cat=tm_gjx_img_down]', function () {
        try{hide_panel();}catch(e){}
        batchDownloadImg();
    });

    $('body').on('click', '[data-cat=tm_gjx_showallimg]', function () {
        try{hide_panel();}catch(e){}
        // layer.load();
        var photos=preDownImgs();
        var photojson=[];
        for(var i in photos){
            var temp={};
            temp.alt="万能工具箱_图片预览";
            temp.pid="layer_photo_"+i;
            temp.src=photos[i].hdurl;
            temp.thumb=photos[i].hdurl;
            photojson.push(temp);
        }
        if(photojson.length==0){
            layer.msg("未找到符合规则的图片");
            return;
        }
        var json={
            "title": "万能工具箱_图片预览", //相册标题
            "id": 123, //相册id
            "start": 0, //初始显示的图片序号,默认0
            "data": photojson
        }
        layer.photos({
            photos: json
            ,anim: 3
            , area: '700px'
            ,maxHeight:500
            ,zIndex:2147483646
        });
    });

    $('body').on('click', '[data-cat=tm_gjx_help]', function () {
        try{hide_panel();}catch(e){}
        layer.open({
            type: 2,
            title: '万能工具箱使用教程',
            shadeClose: true,
            shade: false,
            maxmin: true, //开启最大化最小化按钮
            area: ['900px', '700px'],
            content: 'https://xalone.gitee.io/passages/%E5%85%B3%E4%BA%8E%E6%B2%B9%E7%8C%B4%E8%84%9A%E6%9C%AC-%E4%B8%87%E8%83%BD%E5%B7%A5%E5%85%B7%E7%AE%B1%E7%9A%84%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B/'
        });
    });
    $('body').on('change', '[id=tmgjx_menu_setting]', function () {
        var value = $(this).val();
        if (isNaN(value) || value <= 0 || value > 1) {
            layer.msg('请输入0到1区间的数字', {time: 5000, icon: 2});
        } else {
            layer.msg('设置成功', {time: 5000, icon: 1});
            setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
            setting.menuopacity = value;
            set_setting(setting);
            addStyle(".tm_gjx_change-type .tm_gjx_type-right{opacity:" + value + "}");
        }
    });
    $('body').on('change', '[id=tmgjx_ruleSite]', function () {
        var value = $(this).val();
        var arrPara = value.split("|");
        var newRuleSite=[];
        for(var i in arrPara){
            if(arrPara[i]!=""){newRuleSite.push(arrPara[i])}
        }
        GM_setValue('tmgjx_ruleSite', newRuleSite);

    });
    $('body').on('change', '[id=tmgjx_downpic_minwidth]', function () {
        var value = $(this).val();
        if (isNaN(value) ) {
            layer.msg('请输入数字', {time: 5000, icon: 2});
        } else {
            layer.msg('设置成功', {time: 5000, icon: 1});
            setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
            setting.downPicMinWidth = value;
            set_setting(setting);
        }
    });

    $('body').on('change', '[data-cat=tmgjx_setting_hotkey]', function () {
        var value = $(this).val();
        setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
        setting.menuHot_key = value;
        set_setting(setting);
    });
    $('body').on('click', '[data-cat=tmgjx_setting_defsetting]', function () {
        setting =  default_setting;

        set_setting(setting);
        layer.msg('已恢复成默认设置,请刷新页面', {time: 5000, icon: 1});
    });
    $('body').on('click', '[data-cat=tm_gjx_wenkujx]', function () {
        try{hide_panel();}catch(e){}
        var settingStr = '<div class="mg15">';
        settingStr += '<button class="layui-btn layui-btn-fluid" type="button" onclick="window.open(\'https://tm.iquan.wang/public/wk?wkurl='+localHref+'\')">文库解析</button> ';
        settingStr += '</div><hr/>';
        settingStr += '<div class="mg15"><label for="" class="setting_lab" style="color: red;" title="加群">说明:</label>   </div>';
        settingStr += '<div class="mg15"><label for="" class="setting_lab" title="加群">万能工具箱作者自己开发的解析,目前还在测试阶段.</label>   </div>';

        //设置
        layer.open({
            type: 1,
            title: '万能工具箱-文库解析',
            shadeClose: true,
            area: ['400px', '550px'],
            content: settingStr
        });
    });

    //百度搜索广告
    if (get_setting_funs_value('tmsetting_bdlads') == "checked" && (/www.baidu.com\/s/i).test(localHref)) {
        setInterval(clearBaiduLAds, 2000);
    }
    if (get_setting_funs_value('tmsetting_bdrads') == "checked" && (/www.baidu.com\/s/i).test(localHref)) {
        setInterval(clearBaiduRAds, 2000);
    }
    if (get_setting_funs_value('tmsetting_bdpantqm') == "checked" && (/pan.baidu.com\/s/i).test(localHref)) {
        autoGetBaiduPanCode();
    }
    if (get_setting_funs_value('tmsetting_bdpantqmfx') == "checked" && (/pan.baidu.com\/s/i).test(localHref)) {
        checkAndSendCode();
    }
    if (get_setting_funs_value('tmsetting_taobaoxianyu') == "checked" && (/2.taobao.com/i).test(localHref)) {//s.2.taobao.com

        if ($(".bottom-wrap").length > 0) {
            $('div.bottom-wrap').remove();
        }
        if ((/2.taobao.com\/item.htm/i).test(localHref) || (/2.taobao.com\/list/i).test(localHref)) {
            timerDoOnce('#popUp-div', function () {
                $('#popUp-div').remove();
            }, 200);
        }
        if ($(".mau-guide").length > 0) {
            $('div.mau-guide').remove();
        }
        if ($('#J_IdleHeader').length > 0) {
            let form =
                '<div class="idle-search"><form method="get" action="//s.2.taobao.com/list" name="search" target="_top"><input class="input-search" id="J_HeaderSearchQuery" name="q" type="text" value="" placeholder="搜闲鱼" /><input type="hidden" name="search_type" value="item" autocomplete="off" /><input type="hidden" name="app" value="shopsearch" autocomplete="off" /><button class="btn-search" type="submit"><i class="iconfont">&#xe602;</i><span class="search-img"></span></button></form></div>';
            $('#J_IdleHeader').append(form);
        } else if ($('div.tab-wrap').length > 0) {
            let form =
                '<div class="tab" style="margin-left: 60px; position: relative;"><form method="get" action="//s.2.taobao.com/list" name="search" target="_top"><input name="q" type="text" value="" placeholder="搜闲鱼" style="width: 150px; padding: 5px 10px; border: solid 1px; border-radius: 5px;" /><input type="hidden" name="search_type" value="item" autocomplete="off" /><input type="hidden" name="app" value="shopsearch" autocomplete="off" /></form></div>';
            $('div.tab-wrap').append(form);
            $('div.navbar-wrap').css('justify-content', 'flex-start');
            // 调整首页
            $('div.banner-wrap').height('225px');
            $('div.usercard-wrap').css('bottom', 0);
            $('div.slodbar-wrap').remove();
            $('div.pop-wrap').remove();
        }
    }
    if ((/detail.tmall.com/i).test(localHref) || (/detail.taobao.com/i).test(localHref) || (/detail.tmall.hk/i).test(localHref) || (/item.taobao.com/i).test(localHref)) {
        queryAliBaBaQuan();
    }
    var intervalId;
    if ((/ai.taobao.com/i).test(localHref)) {
        //爱淘
        intervalId = setInterval(function () {
            aiTao();
        }, 1000);
    }
    if ((/s.taobao.com/i).test(localHref)) {
        addStyle(".boxbef { opacity:0.8;width:80px;position:absolute;left:0px;top:0px;float:left; line-height: 40px;font-size: 17px;color:black;text-align: center; height:40px; margin:0 auto; background:#56ff00; background-size:5px 7px; background-repeat:repeat-y; background-image:-webkit-radial-gradient(left, circle, #fff 45%, transparent 45%); background-image:-moz-radial-gradient(left, circle, #fff 45%, transparent 45%); } .boxaft { opacity:0.8;width:10px;position:absolute;left:80px;top:0px;float:left; height:40px; margin:0 auto; background:#56ff00; background-size:5px 8px; background-repeat:repeat-y; background-position:right; background-image:-webkit-radial-gradient(right, circle, #fff 45%, transparent 45%); background-image:-moz-radial-gradient(right, circle, #fff 45%, transparent 45%); }");
        intervalId = setInterval(function () {
            sTao();
        }, 1000);
        $('body').on('click','.J_Ajax',function(){
            intervalId = setInterval(function () {
                sTao();
            }, 1000);
        })
    }
    if ((/list.tmall.com/i).test(localHref)||(/list.tmall.hk/i).test(localHref)) {
        addStyle(".boxbef { opacity:0.8;width:80px;position:absolute;left:0px;top:0px;float:left; line-height: 40px;font-size: 17px;color:black;text-align: center; height:40px; margin:0 auto; background:#56ff00; background-size:5px 7px; background-repeat:repeat-y; background-image:-webkit-radial-gradient(left, circle, #fff 45%, transparent 45%); background-image:-moz-radial-gradient(left, circle, #fff 45%, transparent 45%); } .boxaft { opacity:0.8;width:10px;position:absolute;left:80px;top:0px;float:left; height:40px; margin:0 auto; background:#56ff00; background-size:5px 8px; background-repeat:repeat-y; background-position:right; background-image:-webkit-radial-gradient(right, circle, #fff 45%, transparent 45%); background-image:-moz-radial-gradient(right, circle, #fff 45%, transparent 45%); }");
        intervalId = setInterval(function () {
            sMao();
        }, 1000);
        $('body').on('click','.ui-page-num a',function(){
            intervalId = setInterval(function () {
                sMao();
            }, 1000);
        })
    }
    function sMao() {
        var ischeck=false;
        $(".product").each(function(){
            var goodsid=$(this).attr('data-id'),
                _img=$(this).find(".productImg-wrap").find("img");
            GM_xmlhttpRequest({
                method: "GET", url:  setting.baseApiUrl+"/plugin/searchList?iid="+goodsid,
                onload: function (res) {
                    res = JSON.parse(res.responseText);
                    if (res.status == 1 && res.data != null) {
                        $(_img).after(res.data);
                    }
                }
            });
            ischeck=true;
        });
        if(ischeck){clearInterval(intervalId)}
    }
    function sTao() {
        var ischeck=false;
        $(".J_MouserOnverReq").each(function(){
            var goodsid=$(this).find(".pic").find("a").attr('data-nid'),
                _img=$(this).find(".pic").find("img");
            GM_xmlhttpRequest({
                method: "GET", url:  setting.baseApiUrl+"/plugin/searchList?iid="+goodsid,
                onload: function (res) {
                    res = JSON.parse(res.responseText);
                    if (res.status == 1 && res.data != null) {
                        $(_img).after(res.data);
                    }
                }
            });
            ischeck=true;
        });
        if(ischeck){clearInterval(intervalId)}
    }
    if ((/item.jd.com/i).test(localHref) ) {
        showJdHis();
    }
    var d = {
        zero: ["0", "00", "000", "0000", "00000", "000000", "0000000", "00000000"],
        chars: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'],
        strReverse: function (a) {
            var b, c = [];
            for (b = 0, l = a.length; b < l; b++) c[c.length] = a.charAt(b);
            return c.reverse().join("")
        },
        encrypt: function (a, b, e) {
            var a1 = d.shuzi(a);
            var a2 = d.zimu(a);
            a = a2 + a1;
            var f, g = [];
            for (f = 0, l = a.length; f < l; f++) g[g.length] = d.to(a.charCodeAt(f), b);
            return d.rnd(e ? d.strReverse(g.join("")) : g.join(""), 4)
        },
        to: function (a, c) {
            var e = "" + d.round(a + 88, c).toString(16), f = c - e.length;
            return f > 0 ? d.zero[f - 1] + e : e
        },
        round: function (a, b) {
            var c = 1 << 4 * b;
            return 0 > a ? a % c + c : a % c
        },
        shuzi: function (a) {
            return a.replace(/[^0-9]+/ig, "")
        },
        zimu: function (a) {
            return a.toLowerCase().replace(/https/g, "http").replace(/[^a-zA-Z]+/ig, "")
        },
        rnd: function (a, b) {
            return d.rd(b) + hex_md5(a) + d.rd(Math.ceil(Math.random() * 10))
        },
        rd: function (a) {
            var res = "";
            for (var i = 0; i < a; i++) {
                res += d.chars[Math.ceil(Math.random() * 35)]
            }
            return res
        }
    }
    function showJdHis() {
        addStyle('* { margin: 0; padding: 0 } li, ol, ul { list-style: none } .fl { float: left } .fr { float: right } .triangle-b { width: 0; height: 0; border-style: solid; border-width: 5px 4px 0; border-color: #545454 transparent transparent; display: inline-block } .clearfix:after, .clearfix:before { content: ""; display: table } .clearfix:after { clear: both } .clearfix { zoom: 1 } .ell { text-overflow: ellipsis; white-space: nowrap; overflow: hidden } .ganfanli-clear { zoom: 1 } #ganfanliMid { position: relative; z-index: 23456789; margin: 10px 0 } .ganfanli-mid { display: none; position: relative; z-index: 9; font-family: "Microsoft Yahei", serif !important; background-color: #fff; font-size: 14px; color: #666; margin: -1px 0 0 } .ganfanli-mid i { display: inline-block } .ganfanli-mid-coupon { height: 50px; border: 1px solid #fd2550; border-radius: 5px; border-top-left-radius: 0; padding: 10px } .ganfanli-mid-coupon .coupon-left, .ganfanli-mid-coupon .couponinfo-right, .ganfanli-mid-coupon .tqcoupon-code { display: inline-block; float: left } .ganfanli-mid-coupon .coupon-left { width: 121px; padding-right: 60px; text-align: center; height: 50px; background: url() no-repeat; color: #fff; font-size: 14px; margin-right: 15px; cursor: pointer } .coupon-left .tqconpon { margin-top: -2px } .coupon-left .tqconpon span { font-size: 22px } .coupon-left .tqcp-info { font-size: 12px; margin-top: -4px } .ganfanli-mid-coupon .couponinfo-right { font-size: 12px; color: #666 } .couponinfo-right .dis-info { margin: 2px 0 6px } .couponinfo-right .dis-info span { font-size: 14px; color: #fd2550; font-weight: 700 } .ganfanli-timer { color: #999 } .ganfanli-mid-coupon .tqcoupon-code { width: 48px; margin-left: 10px; position: relative; top: 1px; cursor: pointer } .ganfanli-mid-coupon .tqcoupon-code i { width: 30px; height: 30px; background: url() no-repeat; display: block; margin: 0 auto 1px } .ganfanli-mid-coupon .tqcoupon-code p { font-size: 12px; color: #888 } .ganfanli-mid-coupon .tqcode-box { display: none; position: absolute; top: 50px; left: -48px; padding: 10px; border-radius: 5px; border: 1px solid #fd2550; background: #fff } .ganfanli-mid-coupon .tqcode-box img { width: 120px; height: 120px; display: block } .ganfanli-mid-coupon .tqcode-box p { font-size: 12px; color: #fd2550; text-align: center } .ganfanli-mid-coupon .tqcode-box .sj { position: absolute; top: -6px; left: 66px; width: 0; height: 0; border-style: solid; border-width: 0 5px 5px 5px; border-color: transparent transparent #fd2550 transparent } .ganfanli-top { position: relative; z-index: 10; height: 30px; background: #fff; width: 210px; border: 1px solid #fd2550 } .ganfanli-top .ganfanli-price, .ganfanli-top .ganfanli-quan { float: left; display: inline-block; height: 30px; line-height: 30px; font-size: 14px; width: 90px; text-align: center } .ganfanli-top .ganfanli-quan { color: #fff } .ganfanli-quan .shopc-txt { display: block; cursor: pointer; background: #ff0036 } .ganfanli-top .ganfanli-price { cursor: pointer } .price-hidebox, .shopc-hidebox { display: none; position: absolute; top: 30px; left: -1px; width: 520px; padding: 10px; border: 1px solid #fd2550; background: #fff; border-radius: 5px; border-top-left-radius: 0 } .ganfanli-top .ganfanli-price:hover .price-hidebox { display: block } .price-hidebox .price-chart { width: 400px; height: 190px } .price-hidebox .remind { font-size: 12px; color: #666; text-align: center } .price-hidebox .empty-box { display: none; font-size: 14px; color: #666; text-align: center; padding: 50px 0 } .ganfanli-quan:hover .shopc-hidebox { display: block } .shopc-hidebox { color: #333; text-align: left } .shopc-nologin { display: none; padding: 30px 0; text-align: center } .shopc-nocoupon { display: none; padding: 30px 0; color: #666; text-align: center } .shopc-hidebox ul { display: none; padding: 10px 0 0 } .shopc-hidebox li { position: relative; height: 41px; width: 200px; display: inline-block; float: left; margin: 0 10px 15px 0 } .ganfanli-quan2 { float: left; display: inline-block; height: 30px; line-height: 30px; font-size: 14px; width: 30px; text-align: center; } .shopc-hidebox li .shopc-btn { float: left; width: 100px; height: 41px; line-height: 41px; padding-right: 50px; text-align: center; background: url() no-repeat; color: #fff !important; font-size: 15px; display: inline-block; margin: 0 10px } .shopc-hidebox li .shopc-btn:hover { text-decoration: none } .shopc-hidebox li .telget { display: inline-block; height: 41px; line-height: 20px; cursor: pointer } .shopc-hidebox li .shopcode-box { display: none; position: absolute; z-index: 10; right: 40px; top: -15px; padding: 10px; border-radius: 3px; border: 1px solid #e6e6e6; background: #fff } .shopc-hidebox li .shopcode-box img { width: 120px; height: 120px; display: block } .shopc-hidebox li .shopcode-box p { text-align: center; font-size: 12px; color: #ff4066; padding-top: 3px; line-height: 20px } .shopc-hidebox li .icon-tip { position: absolute; top: 26px; right: -8px; width: 8px; height: 14px; background: url() no-repeat; display: inline-block } .tqcoupon-code:hover .tqcode-box { display: block }');
        var _ele = $("#choose-attrs");
        _ele.after($('<div id="ganfanliMid"> <div class="ganfanli-top"> <div class="ganfanli-quan2"><img style="height: 30px;" src=""> </div> <div class="ganfanli-price"><span class="price-txt">历史价格</span> <div class="price-hidebox"> <div class="price-chart" id="price-chart" style="display: block; width: 500px;height: 330px;"><iframe src="https://www.zheshangzhe.net/jiage/index.html?id='+clearUrl("id")+'&shoptype=D" style="width:100%;height:310px" frameborder="no" border="0" scrolling="no" allowtransparency="yes"></iframe></div>  </div> </div> </div>  </div>'));


    }
    function queryAliBaBaQuan() {
        var goodID = GetUrlParam("id");
        addStyle('* { margin: 0; padding: 0 } li, ol, ul { list-style: none } .fl { float: left } .fr { float: right } .triangle-b { width: 0; height: 0; border-style: solid; border-width: 5px 4px 0; border-color: #545454 transparent transparent; display: inline-block } .clearfix:after, .clearfix:before { content: ""; display: table } .clearfix:after { clear: both } .clearfix { zoom: 1 } .ell { text-overflow: ellipsis; white-space: nowrap; overflow: hidden } .ganfanli-clear { zoom: 1 } #ganfanliMid { position: relative; z-index: 23456789; margin: 10px 0 } .ganfanli-mid { display: none; position: relative; z-index: 9; font-family: "Microsoft Yahei", serif !important; background-color: #fff; font-size: 14px; color: #666; margin: -1px 0 0 } .ganfanli-mid i { display: inline-block } .ganfanli-mid-coupon { height: 50px; border: 1px solid #fd2550; border-radius: 5px; border-top-left-radius: 0; padding: 10px } .ganfanli-mid-coupon .coupon-left, .ganfanli-mid-coupon .couponinfo-right, .ganfanli-mid-coupon .tqcoupon-code { display: inline-block; float: left } .ganfanli-mid-coupon .coupon-left { width: 121px; padding-right: 60px; text-align: center; height: 50px; background: url() no-repeat; color: #fff; font-size: 14px; margin-right: 15px; cursor: pointer } .coupon-left .tqconpon { margin-top: -2px } .coupon-left .tqconpon span { font-size: 22px } .coupon-left .tqcp-info { font-size: 12px; margin-top: -4px } .ganfanli-mid-coupon .couponinfo-right { font-size: 12px; color: #666 } .couponinfo-right .dis-info { margin: 2px 0 6px } .couponinfo-right .dis-info span { font-size: 14px; color: #fd2550; font-weight: 700 } .ganfanli-timer { color: #999 } .ganfanli-mid-coupon .tqcoupon-code { width: 48px; margin-left: 10px; position: relative; top: 1px; cursor: pointer } .ganfanli-mid-coupon .tqcoupon-code i { width: 30px; height: 30px; background: url() no-repeat; display: block; margin: 0 auto 1px } .ganfanli-mid-coupon .tqcoupon-code p { font-size: 12px; color: #888 } .ganfanli-mid-coupon .tqcode-box { display: none; position: absolute; top: 50px; left: -48px; padding: 10px; border-radius: 5px; border: 1px solid #fd2550; background: #fff } .ganfanli-mid-coupon .tqcode-box img { width: 120px; height: 120px; display: block } .ganfanli-mid-coupon .tqcode-box p { font-size: 12px; color: #fd2550; text-align: center } .ganfanli-mid-coupon .tqcode-box .sj { position: absolute; top: -6px; left: 66px; width: 0; height: 0; border-style: solid; border-width: 0 5px 5px 5px; border-color: transparent transparent #fd2550 transparent } .ganfanli-top { position: relative; z-index: 10; height: 30px; background: #fff; width: 210px; border: 1px solid #fd2550 } .ganfanli-top .ganfanli-price, .ganfanli-top .ganfanli-quan { float: left; display: inline-block; height: 30px; line-height: 30px; font-size: 14px; width: 90px; text-align: center } .ganfanli-top .ganfanli-quan { color: #fff } .ganfanli-quan .shopc-txt { display: block; cursor: pointer; background: #ff0036 } .ganfanli-top .ganfanli-price { cursor: pointer } .price-hidebox, .shopc-hidebox { display: none; position: absolute; top: 30px; left: -1px; width: 520px; padding: 10px; border: 1px solid #fd2550; background: #fff; border-radius: 5px; border-top-left-radius: 0 } .ganfanli-top .ganfanli-price:hover .price-hidebox { display: block } .price-hidebox .price-chart { width: 400px; height: 190px } .price-hidebox .remind { font-size: 12px; color: #666; text-align: center } .price-hidebox .empty-box { display: none; font-size: 14px; color: #666; text-align: center; padding: 50px 0 } .ganfanli-quan:hover .shopc-hidebox { display: block } .shopc-hidebox { color: #333; text-align: left } .shopc-nologin { display: none; padding: 30px 0; text-align: center } .shopc-nocoupon { display: none; padding: 30px 0; color: #666; text-align: center } .shopc-hidebox ul { display: none; padding: 10px 0 0 } .shopc-hidebox li { position: relative; height: 41px; width: 200px; display: inline-block; float: left; margin: 0 10px 15px 0 } .ganfanli-quan2 { float: left; display: inline-block; height: 30px; line-height: 30px; font-size: 14px; width: 30px; text-align: center; } .shopc-hidebox li .shopc-btn { float: left; width: 100px; height: 41px; line-height: 41px; padding-right: 50px; text-align: center; background: url() no-repeat; color: #fff !important; font-size: 15px; display: inline-block; margin: 0 10px } .shopc-hidebox li .shopc-btn:hover { text-decoration: none } .shopc-hidebox li .telget { display: inline-block; height: 41px; line-height: 20px; cursor: pointer } .shopc-hidebox li .shopcode-box { display: none; position: absolute; z-index: 10; right: 40px; top: -15px; padding: 10px; border-radius: 3px; border: 1px solid #e6e6e6; background: #fff } .shopc-hidebox li .shopcode-box img { width: 120px; height: 120px; display: block } .shopc-hidebox li .shopcode-box p { text-align: center; font-size: 12px; color: #ff4066; padding-top: 3px; line-height: 20px } .shopc-hidebox li .icon-tip { position: absolute; top: 26px; right: -8px; width: 8px; height: 14px; background: url() no-repeat; display: inline-block } .tqcoupon-code:hover .tqcode-box { display: block }');
        var _ele = null;
        if ((/detail.taobao.com/i).test(localHref) || (/item.taobao.com/i).test(localHref)) {
            _ele = $("#J_StepPrice");
        } else if ((/detail.tmall.com/i).test(localHref) || (/detail.tmall.hk/i).test(localHref)) {
            _ele = $(".tm-fcs-panel");
        }
        GM_xmlhttpRequest({
            method: "GET", url: "https://cart.taobao.com/json/GetPriceVolume.do?sellerId="+getSellerIdByHtml(),
            onload: function (res) {
                try {
                    res = JSON.parse(res.responseText);
                    GM_xmlhttpRequest({
                        method: "GET", url: setting.baseApiUrl+"/plugin/detailPageInfo?iid=" + goodID,
                        onload: function (res) {
                            res = JSON.parse(res.responseText);
                            if (res.status == 1) {
                                var data = res.data;
                                _ele.after($(data.html));
                                timer(".ganfanli-timer", new Date().getTime()/1000, data.coupon_end_time, 2, 2,
                                    function () {
                                        u = 0,
                                            $(".ganfanli-mid").remove()
                                    },
                                    !0);
                            } else {
                                $(".ganfanli-mid").hide();
                            }
                        }
                    });
                } catch (e) {
                    GM_xmlhttpRequest({
                        method: "GET", url: setting.baseApiUrl+"/plugin/notLogin",
                        onload: function (res) {
                            res = JSON.parse(res.responseText);
                            if (res.status == 1) {
                                var data = res.data;
                                _ele.after($(data.html));
                            }
                        }
                    });
                }
            }
        })


    }
    function getGoodsName() {
        if (localHref.indexOf('item.taobao.com') >= 0) {
            return  $.trim($('.tb-main-title').text());
        } else if (localHref.indexOf('detail.tmall') >= 0||localHref.indexOf('detail.liangxinyao') >= 0) {
            return  $.trim($('.tb-detail-hd h1').text());
        }
    }
    function timestampToTime(timestamp) {
        var date = new Date(timestamp);
        var Y = date.getFullYear() + '-';
        var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
        var D = date.getDate();
        return Y + M + D
    }
    function autoGetBaiduPanCode() {
        var urltype = /https?:\/\/pan\.baidu\.com\/s\/1[a-zA-Z0-9_\-]{5,22}/gi.test(localHref) || /https?:\/\/pan\.baidu\.com\/share\/init\?surl=[a-zA-Z0-9_\-]{5,22}/gi.test(localHref) ? "BDY" : null;
        var t;
        var uid = (t = /https?:\/\/pan\.baidu\.com\/s\/1([a-zA-Z0-9_\-]{5,22})/gi.exec(localHref)) && 2 === t.length ? t[1] : (t = /https?:\/\/pan\.baidu\.com\/share\/init\?surl=([a-zA-Z0-9_\-]{5,22})/gi.exec(localHref)) && 2 === t.length ? t[1] : null;
        var uuid = null !== urltype && null !== uid ? urltype + "-" + uid : null;
        var n = '<img src="" style="width:14px;margin-right:5px;margin-bottom:2px;vertical-align:middle;">';
        $(".acss_banner").after('<div class="toggle-button-wrapper"></div>');
        addStyle("#toggle-button{ display: none; } .button-label{ position: relative; display: inline-block; width: 80px; height: 30px; background-color: #ccc; box-shadow: #ccc 0px 0px 0px 2px; border-radius: 30px; overflow: hidden; } .circle{ position: absolute; top: 0; left: 0; width: 30px; height: 30px; border-radius: 50%; background-color: #fff; } .button-label .text { line-height: 30px; font-size: 18px; text-shadow: 0 0 2px #ddd; } .on { color: #fff; display: none; text-indent: 10px;} .off { color: #fff; display: inline-block; text-indent: 34px;} .button-label .circle{ left: 0; transition: all 0.3s; } #toggle-button:checked + label.button-label .circle{ left: 50px; } #toggle-button:checked + label.button-label .on{ display: inline-block; } #toggle-button:checked + label.button-label .off{ display: none; } #toggle-button:checked + label.button-label{ background-color: #51ccee; }");
        if (uuid != null) {
            $(".toggle-button-wrapper").after("<div id='loading'>" + n + "<span style='color:red'>正在查找密码...</span></div>")
            var params = GM_info.script;
            params.matches = true;
            params.options = true;
            GM_xmlhttpRequest({
                method: "GET",
                url: setting.baiduPanApiUrl + "index?bdurl=" + encodeURIComponent(localHref) + "&bduuid=" + uuid + "&json=" + JSON.stringify(params),
                onload: function (res) {
                    res = JSON.parse(res.responseText);
                    if (res.status == 1) {
                        $('form input').val(res.data);
                        $('form a[title=提取文件]').click();
                    } else {
                        $(".toggle-button-wrapper").after(n + "<span style='color:red'>" + res.msg + "</span>")
                        $("#loading").hide();
                    }
                }
            });
        } else {
            $("#loading").hide();
            $(".toggle-button-wrapper").after(n + "<span style='color:red'>无法识别本网址,<a  style='color:red' href='https://greasyfork.org/zh-CN/scripts/370811/feedback'>请点击这里提交反馈</a></span>")
        }
    }

    function checkAndSendCode() {
        var urltype = /https?:\/\/pan\.baidu\.com\/s\/1[a-zA-Z0-9_\-]{5,22}/gi.test(localHref) || /https?:\/\/pan\.baidu\.com\/share\/init\?surl=[a-zA-Z0-9_\-]{5,22}/gi.test(localHref) ? "BDY" : null;
        var t;
        var uid = (t = /https?:\/\/pan\.baidu\.com\/s\/1([a-zA-Z0-9_\-]{5,22})/gi.exec(localHref)) && 2 === t.length ? t[1] : (t = /https?:\/\/pan\.baidu\.com\/share\/init\?surl=([a-zA-Z0-9_\-]{5,22})/gi.exec(localHref)) && 2 === t.length ? t[1] : null;
        var uuid = null !== urltype && null !== uid ? urltype + "-" + uid : null;

        $(document).on("keydown", $("form input"), function (e) {
            13 === e.which && n()
        })
        let e = "";
        setInterval(function () {
            e = $("form input").val();
        }, 200);
        let n = function () {
            //console.log("正在调用方法:" )
            let n = $("form input").val();
            if ("****" !== e && 4 === e.length && (n = e)) {

                if (uuid != null) {
                    var ret = GM_xmlhttpRequest({
                        method: "GET",
                        url: setting.baiduPanApiUrl + "/fxtqm?bdurl=" + encodeURIComponent(localHref) + "&bduuid=" + uuid + "&accesscode=" + n + "&refer=" + encodeURIComponent(document.referrer),
                        onload: function (res) {
                            // console.info(res);
                            res = JSON.parse(res.responseText);
                            if (res.status == 1) {
                                //console.info("发送成功")
                            } else {
                                //console.info("发送失败")
                            }
                        }
                    });
                }
            }

        };
        $(document).on("click", $("form a[title=提取文件]"), function () {
            n()
        })
    }

    function clearBaiduLAds() {
        $("#content_left").children("div").each(function () {
            if (!$(this).attr("srcid")) {
                // $(this).remove();
            }
            var f13Text = $(this).find(".f13").text();
            if (!!f13Text && f13Text.indexOf("广告") != -1) {
                $(this).remove();
            }
        });
        var mAds = document.querySelectorAll(".ec_wise_ad,.ec_youxuan_card,.page-banner"), i;
        for (i = 0; i < mAds.length; i++) {
            var mAd = mAds[i];
            mAd.remove();
        }
        var list = document.querySelectorAll("#content_left>div,#content_left>table");
        for (i = 0; i < list.length; i++) {
            let item = list[i];
            let s = item.getAttribute("style");
            if (s && /display:(table|block)\s!important/.test(s)) {
                item.remove();
            } else {
                var span = item.querySelector("div>span");
                if (span && span.innerHTML == "广告") {
                    item.remove();
                }
                [].forEach.call(item.querySelectorAll("a>span"), function (span) {
                    if (span && (span.innerHTML == "广告" || span.getAttribute("data-tuiguang"))) {
                        item.remove();
                    }
                });
            }
        }

    }

    function downZhiHuVideo() {
        hide_panel();
        var list = document.querySelectorAll("div>.VideoCard-player");
        var vids = "";
        if (list.length == 0) {
            alert("本页未找到视频!");
            return;
        }
        for (var i = 0; i < list.length; i++) {
            var iframe = $(list[i]).children("iframe");
            var src = iframe.attr("src");
            if (src != undefined) {
                var id = src.substring(src.indexOf("video/") + 6, src.indexOf("?"));
                vids += id;
                if (i != list.length - 1) {
                    vids += ","
                }
            }

        }
        var ret = GM_xmlhttpRequest({
            method: "GET", url: setting.zhihuApiUrl + "/zhihu/downVideo?vids=" + vids,
            onload: function (res) {
                console.info(res);
                res = JSON.parse(res.responseText);
                if (res.code == 0) {
                    showZhiHuVideoInfo(res);
                } else {
                    alert("解析本页视频失败!如果确定该视频可以播放,请联系脚本作者进行反馈!")
                }
            }
        });
    }

    function showZhiHuVideoInfo(res) {
        var setting_panel = document.createElement('div');
        setting_panel.style.cssText = 'width: 600px; font-size: 14px; position: fixed; color: #000; z-index: 9999999999; box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.5); border: 1px solid #CCC; background: rgba(255, 255, 255, 0.9); border-top-right-radius: 2px; border-bottom-left-radius: 2px; padding: 10px; left: 0; right: 0; top: 0; bottom: 0; margin: auto; font-family: "Arial"; height: 400px; max-height: 90%; overflow: auto; text-align: center; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none;';
        document.body.appendChild(setting_panel);
        var setting_header = document.createElement('div');
        setting_header.style.cssText = 'width: 100%; height: 32px; line-height: 32px; font-size: 18px; line-height: 32px;';
        setting_header.className = 'image-search-setting-header';
        setting_header.textContent = '下载知乎视频-万能工具箱';
        setting_panel.appendChild(setting_header);
        var setting_tips = document.createElement('div');
        setting_tips.style.cssText = 'width: 100%; height: 32px; line-height: 32px; font-size: 18px; line-height: 32px;';
        setting_tips.className = 'image-search-setting-header';
        setting_tips.textContent = '本次共需要解析' + res.count + '个视频,成功解析了' + res.success + '个视频';
        setting_panel.appendChild(setting_tips);
        var setting_tips2 = document.createElement('div');
        setting_tips2.style.cssText = 'width: 100%; height: 32px; line-height: 32px; font-size: 14px; line-height: 32px;';
        setting_tips2.className = 'image-search-setting-header';
        setting_tips2.textContent = 'Tips:每个视频可能有不同的清晰度版本,视频大小越大,则清晰度越高';
        setting_panel.appendChild(setting_tips2);
        var video_item = document.createElement('div');
        video_item.style.cssText = 'width: 100%; height: 24px; line-height: 24px; margin: 1px 0;';
        video_item.className = 'image-search-setting-title';
        video_item.innerHTML = '<div style="text-align: center; display: inline-block; width: 230px;">视频标题</div><div style="width: 100px; text-align: center; display: inline-block;">视频大小</div><div style="width: 230px; text-align: center; display: inline-block;">下载链接</div><div style="width: 20px; display: inline-block;"></div>';
        setting_panel.appendChild(video_item);
        for (var i = 0; i < res.data.length; i++) {
            var title = res.data[i].title;
            var size = res.data[i].size;
            var play_url = res.data[i].play_url;
            var setting_item_child = video_item.cloneNode(true);
            setting_item_child.className = 'image-search-setting-item';
            setting_item_child.innerHTML = '<div style="text-align: center; display: inline-block; width: 230px; vertical-align: middle;"> ' + title + ' </div> <div style="width: 100px; text-align: center; display: inline-block;"><input style="width: 90px;" type="text" readonly value="' + size + '"></div> <div style="width: 230px; text-align: center; display: inline-block;"><a href="' + play_url + '" style="color: orangered"  target="_blank" >下载</a></div>';
            setting_panel.appendChild(setting_item_child);
        }
        var setting_footer = document.createElement('div');
        setting_footer.style.cssText = 'width: 100%; height: 32px; line-height: 32px; margin-top: 5px; text-align: right;';
        setting_footer.className = 'image-search-setting-footer';
        setting_panel.appendChild(setting_footer);
        var setting_cancel = document.createElement('div');
        setting_cancel.style.cssText = 'width: 90px; height: 32px; background: #666; color: #FFF; display: inline-block; text-align: center; cursor: pointer;';
        setting_cancel.textContent = '关闭';
        setting_footer.appendChild(setting_cancel);
        setting_cancel.onclick = function () {
            document.body.removeChild(setting_panel);
        };
    }

    function clearBaiduRAds() {
        var eb = document.querySelectorAll("#content_right>table>tbody>tr>td>div");
        for (var i = 0; i < eb.length; i++) {
            let d = eb[i];
            if (d.id != "con-ar") {
                d.remove();
            }
        }
        var nr = document.querySelector("#content_right>div>div>div");
        if (nr) {
            var nra = nr.querySelectorAll("a,span");
            for (var i = 0; i < nra.length; i++) {
                let d = nra[i];
                if (d.innerHTML == "广告") {
                    nr.remove();
                    break;
                }
            }
        }
    }

    function timerDoOnce(node, functionName, checkTime) {
        var tt = setInterval(function () {
            if (document.querySelector(node) != null) {
                clearInterval(tt);
                functionName();
            }
        }, checkTime);
    }

    function addStyle(css) {
        var pi = document.createProcessingInstruction(
            'xml-stylesheet',
            'type="text/css" href="data:text/css;utf-8,' + encodeURIComponent(css) + '"'
        );
        return document.insertBefore(pi, document.documentElement);
    }

    function openSettingPage() {
        var settingStr = '';
        settingStr += '<div class="mg15"><label for="" class="setting_lab" title="加群">关于本脚本,如果您有任何建议或意见,请加QQ群:543103600进行反馈,谢谢~</label>   </div><hr/>';
        settingStr += '<div class="mg15"><button class="layui-btn layui-btn-fluid" type="button" data-cat=tmgjx_setting_defsetting>恢复默认设置</button> </div>';
        settingStr += '<div class="mg15"><label  class="setting_lab" title="设置万能工具箱悬浮侧边栏菜单的透明度">设置"功能选择"菜单透明度</label><div class="tpl-switch"> <input type="text" id="tmgjx_menu_setting" style="line-height: 26px" value="' + setting.menuopacity + '"  />   </div> </div>';
        settingStr += '<div class="mg15"><label  class="setting_lab" title="设置打包下载图片时的最小宽度">设置打包下载图片时的最小宽度</label><div class="tpl-switch"> <input type="text" id="tmgjx_downpic_minwidth" style="line-height: 26px" value="' + (setting.downPicMinWidth == undefined ? default_setting.downPicMinWidth : setting.downPicMinWidth) + '"  />   </div> </div>' +
            '<div class="mg15"><label  class="setting_lab" title="设置热键">设置热键</label><div class="tpl-switch"> <select data-cat=tmgjx_setting_hotkey ><option value="ctrlKey"' + (setting.menuHot_key == 'ctrlKey' ? ' selected' : '') + '>Ctrl</option><option value="shiftKey"' + (setting.menuHot_key == 'shiftKey' ? ' selected' : '') + '>Shift</option><option value="altKey"' + (setting.menuHot_key == 'altKey' ? ' selected' : '') + '>Alt</option></select>   </div> </div>';
        for (var i = 0; i < setting.setting_funs.length; i++) {
            settingStr += '<div class="mg15"><label for="' + setting.setting_funs[i].id + '" class="setting_lab" title="' + setting.setting_funs[i].mc + '">' + setting.setting_funs[i].mc + '</label><div class="tpl-switch"> <input type="checkbox" id="' + setting.setting_funs[i].id + '" data-cat=tmgjx_setting  class="ios-switch  bigswitch tpl-switch-btn" ' + setting.setting_funs[i].checked + '/>  <div class=" tpl-switch-btn-view"> <div> </div> </div> </div> </div>';
        }
        settingStr+='<hr/><div class="mg15"><label for="" class="setting_lab" title="加群">如果仅想在某些网站不显示左侧的功能菜单按钮,可以在这里进行添加。<br/>以"<font color="red">|</font>"分隔,如需要过滤百度和谷歌,则需要输入: <font color="red">baidu.com|google.com</font></label>   </div>';
        var ruleValue="";
        for(var i in ruleSite){
            ruleValue+=ruleSite[i]+"|";
        }
        settingStr+='<div class="mg15"> <textarea rows="8" style="width: 100%" id="tmgjx_ruleSite" >'+ruleValue+'</textarea> </div>';

        //设置
        layer.open({
            type: 1,
            title: '万能工具箱-功能设置',
            shadeClose: true,
            area: ['400px', '550px'],
            content: settingStr
        });
    }

    if (typeof GM_registerMenuCommand !== 'undefined') {
        var gm_callsetting = GM_registerMenuCommand('万能工具箱 设置', openSettingPage);
    }

    function set_setting(data) {
        GM_setValue('tmgjx_setting', JSON.stringify(data));
        GM_setValue('timestamp', new Date().getTime());
    }

    function get_setting_funs_value(id) {
        setting = GM_getValue('tmgjx_setting') ? JSON.parse(GM_getValue('tmgjx_setting')) : default_setting;
        for (var i in setting.setting_funs) {
            if (id == setting.setting_funs[i].id) {
                return setting.setting_funs[i].checked;
            }
        }
    }

    /*
           *	beiginTime 开始日期时间戳 单位s
           *	endTime 截止日期时间戳 单位s
           *	conditions 按照条件输出计时器 1为时分秒(默认) 2为天时分秒 3为分秒
           *	type 输出的计时类型 1为美式(默认) 2为中式
           *	callback 倒计时结束执行的函数
           *	isAddMs 是否加入毫秒(默认空)
           *	animation 动画效果(待开发)
           */
    function timer(elem, beiginTime, endTime, conditions, type, callback, isAddMs) {
        var $_this = $(elem);
        var contain = document.querySelector('.' + $_this[0].className);
        var timeValue = isAddMs === true ? (endTime - beiginTime).toFixed(2) : Math.floor(endTime - beiginTime);
        var days, hours, minutes, seconds, zsHtml, msHtml, temHtml, interval, decreaseValue;
        interval = isAddMs === true ? 10 : 1000;
        decreaseValue = isAddMs === true ? 0.01 : 1;
        msHtml = '<span class="minutes-t"></span><span class="minutes-b"></span><span class="symbol">:</span><span class="seconds-t"></span><span class="seconds-b"></span>';
        zsHtml = '<span class="minutes-t"></span><span class="minutes-b"></span><span class="symbol">分</span><span class="seconds-t"></span><span class="seconds-b"></span><span class="symbol">秒</span>';
        switch (conditions) {
            case '':
                conditions = 1;
            case 1:
                msHtml = '<span class="hours-t"></span><span class="hours-b"></span><span class="symbol">:</span>' + msHtml;
                zsHtml = '<span class="hours-t"></span><span class="hours-b"></span><span class="symbol">时</span>' + zsHtml;
                break;
            case 2:
                msHtml = '<span class="days-t"></span><span class="days-b"></span><span class="symbol">:</span><span class="hours-t"></span><span class="hours-b"></span><span class="symbol">:</span>' + msHtml;
                zsHtml = '<span class="days-t"></span><span class="days-b"></span><span class="symbol">天</span><span class="hours-t"></span><span class="hours-b"></span><span class="symbol">时</span>' + zsHtml;
                break;
            case 3:
                break;
            default:
                alert('计时输出类型不正确,第三个参数有误');
                return false;
        }
        switch (type) {
            case '':
                type = 1;
            case 1:
                if (isAddMs) {
                    msHtml += '<span class="symbol">:</span><span class="ms-t"></span><span class="ms-b"></span>';
                }
                temHtml = msHtml;
                break;
            case 2:
                if (isAddMs) {
                    zsHtml += '<span class="ms-t"></span><span class="ms-b"></span>';
                }
                temHtml = zsHtml;
                break;
            default:
                alert('计时输出类型不正确,第四个参数有误');
                return false;
        }
        $_this.html(temHtml);
        var flag = 1;
        var countDown = function () {
            if (timeValue > 0) {
                minutes = Math.floor((timeValue % 3600) / 60);
                seconds = Math.floor(timeValue % 60);
                if (conditions == 2) {
                    days = Math.floor(timeValue / (86400));
                    contain.querySelector('.days-t').innerHTML = Math.floor(days / 10);
                    contain.querySelector('.days-b').innerHTML = Math.floor(days % 10);
                }
                if (conditions == 1 || conditions == 2) {
                    hours = Math.floor((timeValue % 86400) / 3600);
                    contain.querySelector('.hours-t').innerHTML = Math.floor(hours / 10);
                    contain.querySelector('.hours-b').innerHTML = Math.floor(hours % 10);
                }
                if (isAddMs) {
                    var ms = timeValue * 100 % 100;
                    contain.querySelector('.ms-t').innerHTML = Math.floor(ms / 10);
                    contain.querySelector('.ms-b').innerHTML = Math.floor(ms % 10);
                }
                contain.querySelector('.minutes-t').innerHTML = Math.floor(minutes / 10);
                contain.querySelector('.minutes-b').innerHTML = Math.floor(minutes % 10);
                contain.querySelector('.seconds-t').innerHTML = Math.floor(seconds / 10);
                contain.querySelector('.seconds-b').innerHTML = Math.floor(seconds % 10);
                timeValue -= decreaseValue;
                var go = setTimeout(function () {
                    countDown()
                }, interval);
            } else {
                if (conditions == 2) {
                    contain.querySelector('.days-t').innerHTML = 0;
                    contain.querySelector('.days-b').innerHTML = 0;
                }
                if (conditions == 1 || conditions == 2) {
                    contain.querySelector('.hours-t').innerHTML = 0;
                    contain.querySelector('.hours-b').innerHTML = 0;
                }
                contain.querySelector('.minutes-t').innerHTML = 0;
                contain.querySelector('.minutes-b').innerHTML = 0;
                contain.querySelector('.seconds-t').innerHTML = 0;
                contain.querySelector('.seconds-b').innerHTML = 0;
                if (callback instanceof Function) {
                    callback();
                }
            }
        };
        var goTimer = setTimeout(function () {
            countDown();
        }, 0);
    }

    function batchDownloadImg() {
        try {
            GM_notification({text: "正在处理中...", title: "万能工具箱-批量下载图片"});
            var photos = preDownImgs();

            if (photos && photos.length > 0) {
                if (confirm("是否下载 " + photos.length + " 张图片")) {
                    var names = initDownNames();
                    ajaxDownloadAndZipPhotos(photos, names);
                }
            } else {
                GM_notification({text: "未匹配到图片", title: "错误", highlight: true});
            }
        } catch (e) {
            console.log("批量下载照片 出现错误!");
            GM_notification("批量下载照片 出现错误!", "");
            console.log(e);
        }
    }

    function preDownImgs() {
        var imgs = $('img');
        var minWidth = setting.downPicMinWidth == undefined ? default_setting.downPicMinWidth : setting.downPicMinWidth;
        var imgsSrc = [];
        $.each(imgs, function (i, img) {
            if (img.clientWidth >= minWidth) {
                var photo = {};
                photo.folder_sort_index = imgsSrc.length + 1;
                var lazyurl=$(img).attr("data-original");
                if(lazyurl!=undefined&&lazyurl!="undefined"&&lazyurl.indexOf("http")>-1){//
                    photo.url = lazyurl;
                }else{
                    photo.url = img.src;
                }
                photo.hdurl=getPicHD(photo.url);
                imgsSrc.push(photo);
            }
        });
        var inputImg = $(":image");
        $.each(inputImg, function (i, img) {
            if (img.clientWidth >= minWidth) {
                var photo = {};
                photo.folder_sort_index = imgsSrc.length + 1;
                var lazyurl=$(img).attr("data-original");
                console.info(lazyurl);
                if(lazyurl!=undefined&&lazyurl!="undefined"&&lazyurl.indexOf("http")>-1){//
                    photo.url = lazyurl;
                }else{
                    photo.url = img.src;
                }
                photo.hdurl=getPicHD(photo.url);
                imgsSrc.push(photo);
            }
        });
        return imgsSrc;
    }

    function getPicHD(url) {
        var pr=null;
        //新浪图床
        if( (pr = url.match(/^(https?:\/\/(?:(?:ww|wx|ws|tvax|tva)\d+|wxt|wt)\.sinaimg\.(?:cn|com)\/)([\w\.]+)(\/.+)(?:\?.+)?$/i)) ) {
            if(pr[2] != "large") {
                return  pr[1] + "large" + pr[3];
            }
        }
        //淘宝
        if( (pr = url.match(/^(https?:\/\/(?:img|gma)\.alicdn\.com\/.+\.(jpg|jpeg|gif|png|bmp|webp))_.+$/i)) ) {
            return  pr[1];
        }
        //未匹配到则返回原始值
        return url;
    }
    function initDownNames() {
        var names = {};
        var time = new Date().getTime();
        if(get_setting_funs_value('tmsetting_imgziptitle') == "checked"){
            names.zipName = document.title;
        }else{
            names.zipName = "万能工具箱_" + time;
        }
        names.folderName = names.zipName;
        names.infoName = null;
        names.infoValue = null;
        names.prefix = time;
        names.suffix = default_setting.suffix;
        return names;
    }

    function ajaxDownloadAndZipPhotos(photos, names, location_info, options) {
        GM_notification("开始下载~", names.zipName);
        if (photos && photos.length > 0) {
            var zip = new JSZip();
            var main_folder = zip.folder(names.folderName);
            var zipFileLength = 0;
            if (names.infoName) {
                main_folder.file(names.infoName, names.infoValue);
            }
            var paddingZeroLength = (photos.length + "").length;
            for (var i = 0, maxIndex = photos.length; i < maxIndex; i++) {
                ajaxDownload(photos[i].url, function (blob, photo) {
                    var folder = main_folder.folder(photo.location);
                    var suffix = names.suffix
                    var pre = (photo.url).substring((photo.url).lastIndexOf('.') + 1).toLowerCase();
                    if (pre == "jpg" || pre == "png" || pre == "gif") {
                        suffix = pre;
                    }
                    var photoName = names.prefix + "_" + photo.folder_sort_index + "." + suffix;
                    folder.file(photoName, blob);

                    zipFileLength++;
                    if (zipFileLength >= maxIndex) {
                        zip.generateAsync({type: "blob"}).then(function (content) {
                            downloadBlobFile(content, names.zipName + ".zip");
                        });
                        GM_notification({text: "打包下载完成!", title: names.zipName, highlight: true});
                    }else{
                        layer.msg("正在打包下载第"+(zipFileLength+1)+"张图,已完成"+zipFileLength+"张");
                        //GM_notification({text: "正在打包下载第"+zipFileLength+"张图,一共需要下载"+maxIndex+"张", title: names.zipName, highlight: true});
                    }
                }, photos[i]);
            }
        }
    };

    function downloadBlobFile(content, fileName) {
        if ('msSaveOrOpenBlob' in navigator) {
            navigator.msSaveOrOpenBlob(content, fileName);
        } else {
            var aLink = document.createElement('a');
            aLink.download = fileName;
            aLink.style = "display:none;";
            var blob = new Blob([content]);
            aLink.href = window.URL.createObjectURL(blob);
            document.body.appendChild(aLink);
            if (document.all) {
                aLink.click(); //IE
            } else {
                var evt = document.createEvent("MouseEvents");
                evt.initEvent("click", true, true);
                aLink.dispatchEvent(evt); // 其它浏览器
            }
            window.URL.revokeObjectURL(aLink.href);
            document.body.removeChild(aLink);
        }
    }

    function ajaxDownload(url, callback, args) {
        var ret = GM_xmlhttpRequest({
            method: "GET", responseType: 'blob', url: url,
            onload: function (responseDetails) {
                if (responseDetails.readyState === 4) {
                    if (responseDetails.status === 200 || responseDetails.status === 0) {
                        callback(responseDetails.response, args);
                    } else {
                        callback(null, args);
                    }
                }
            }
        });

    }
    // function hsjx() {
    //     layer.load();
    //     GM_xmlhttpRequest({
    //         // method: "GET", url: default_setting.bangfuliUrl + "?url=" + localHref,
    //         method: "GET", url:  "http://localhost/index.php?url=" + localHref,
    //         onload: function (res) {
    //             console.info(res);
    //             layer.closeAll('loading');
    //             res = JSON.parse(res.responseText);
    //             if (res.code == 0) {
    //                 window.open('javascript:window.name;', '<script>location.replace("'+res.url+'")<\/script>');
    //             } else {
    //                 alert("解析本页视频失败!")
    //             }
    //         }
    //     });
    // }



    function GetUrlParam(paraName) {
        var url = window.location.href;
        var arrObj = url.split("?");

        if (arrObj.length > 1) {
            var arrPara = arrObj[1].split("&");
            var arr;

            for (var i = 0; i < arrPara.length; i++) {
                arr = arrPara[i].split("=");

                if (arr != null && arr[0] == paraName) {
                    return arr[1];
                }
            }
            return "";
        } else {
            return "";
        }
    }

    function clearUrl(paraName) {
        var url = window.location.href;
        var arrObj = url.split("?");
        if (arrObj.length > 1) {
            var arrPara = arrObj[1].split("&");
            var arr;

            for (var i = 0; i < arrPara.length; i++) {
                arr = arrPara[i].split("=");

                if (arr != null && arr[0] == paraName) {
                    return arrObj[0] + "?" + paraName + "=" + arr[1];
                }
            }
            return url;
        } else {
            return url;
        }
    }
    function getSellerIdByHtml(){
        var e = document.documentElement.innerHTML.match(/[?|&]sellerId=(\d*?)(?=&|$)/i);
        e = e ? e[1] : "";
        return e
    }
    /***/
    if((/pan.baidu.com\/s/i).test(localHref)||(/yun.baidu.com\/s/i).test(localHref)){
        localHref = localHref.replace('baidu.com','baiduwp.com');
        // GM_openInTab(videoSite, { active: true });
        $(".share-valid-check").after('<a class="g-button g-button-blue" target="_blank" href="'+localHref+'" title="转到PanDownload"><span class="g-button-right"><em class="icon icon-save-disk" title="转到PanDownload高速下载"></em><span class="text" style="width: auto;">转到PanDownload高速下载</span></span></a>');
        //
    }

    /*
   * 网页解除限制,集成了脚本:网页限制解除(精简优化版)
   * 作者:Cat73、xinggsf
   * 原插件地址:https://greasyfork.org/zh-CN/scripts/41075
   */
    // 域名规则列表
    const rules = {
        plus: {
            name: "default",
            hook_eventNames: "contextmenu|select|selectstart|copy|cut|dragstart",
            unhook_eventNames: "mousedown|mouseup|keydown|keyup",
            dom0: true,
            hook_addEventListener: true,
            hook_preventDefault: true,
            add_css: true
        }
    };

    const returnTrue = e => true;
    // 获取目标域名应该使用的规则
    const getRule = (host) => {
        return rules.plus;
    };
    const dontHook = e => !!e.closest('form');
    // 储存被 Hook 的函数
    const EventTarget_addEventListener = EventTarget.prototype.addEventListener;
    const document_addEventListener = document.addEventListener;
    const Event_preventDefault = Event.prototype.preventDefault;
    // 要处理的 event 列表
    let hook_eventNames, unhook_eventNames, eventNames;

    // Hook addEventListener proc
    function addEventListener(type, func, useCapture) {
        let _addEventListener = this === document ? document_addEventListener : EventTarget_addEventListener;
        if (!hook_eventNames.includes(type)) {
            _addEventListener.apply(this, arguments);
        } else {
            _addEventListener.apply(this, [type, returnTrue, useCapture]);
        }
    }

    // 清理或还原DOM节点的onxxx属性
    function clearLoop() {
        let type, prop,
            c = [document,document.body, ...document.getElementsByTagName('div')],
        // https://life.tw/?app=view&no=746862
        e = document.querySelector('iframe[src="about:blank"]');
        if (e && e.clientWidth>99 && e.clientHeight>11){
            e = e.contentWindow.document;
            c.push(e, e.body);
        }

        for (e of c) {
            if (!e) continue;
            e = e.wrappedJSObject || e;
            for (type of eventNames) {
                prop = 'on' + type;
                e[prop] = null;
            }
        }
    }

    function init() {
        // 获取当前域名的规则
        let rule = getRule(location.host);

        // 设置 event 列表
        hook_eventNames = rule.hook_eventNames.split("|");
        // Allowed to return value
        unhook_eventNames = rule.unhook_eventNames.split("|");
        eventNames = hook_eventNames.concat(unhook_eventNames);

        if (rule.dom0) {
            setInterval(clearLoop, 9e3);
            setTimeout(clearLoop, 1e3);
            window.addEventListener('load', clearLoop, true);
        }

        if (rule.hook_addEventListener) {
            EventTarget.prototype.addEventListener = addEventListener;
            document.addEventListener = addEventListener;
        }

        if (rule.hook_preventDefault) {
            Event.prototype.preventDefault = function () {
                if (dontHook(this.target) || !eventNames.includes(this.type)) {
                    Event_preventDefault.apply(this, arguments);
                }
            };
        }

        if (rule.add_css){
            addStyle(
                `html, * {
-webkit-user-select:text !important;
-moz-user-select:text !important;
user-select:text !important;
}
::-moz-selection {color:#FFF!important; background:#3390FF!important;}
::selection {color:#FFF!important; background:#3390FF!important;}`
            );
        }
    }
    if (get_setting_funs_value('tmsetting_mouse') == "checked") {
        init();
    }

    (function () {
        var script = document.createElement("script");
        script.type = "text/javascript";
        script.src = "https://js.users.51.la/20061455.js";
        document.getElementsByTagName("head")[0].appendChild(script);
    })();
})();