Greasy Fork

来自缓存

一键复制美剧链接

识别常用网址的美剧链接,实现一键复制,美剧天堂修改按钮

目前为 2021-07-30 提交的版本。查看 最新版本

// ==UserScript==
// @name         一键复制美剧链接
// @namespace    http://tampermonkey.net/
// @version      1.3
// @description  识别常用网址的美剧链接,实现一键复制,美剧天堂修改按钮
// @author       Bleu
// @match        https://www.meijutt.tv/*
// @match        https://www.22tu.tv/*
// @match        https://www.kpkuang.com/*
// @match        https://www.mp4er.com/*
// @match        https://91mjw.com/*
// @match        https://www.ttmeiju.org/*
// @match        https://pan.xunlei.com/*
// @match        https://pan.baidu.com/*
// @grant        GM_setClipboard
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_addStyle
// @grant        GM_openInTab
// @run-at       document-end
// @require      https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js
/* globals jQuery, $, waitForKeyElements ,exit*/
// ==/UserScript==

(function () {
    'use strict';

    const webName = ['meijutt','91mjw','22tu','kpkuang','mp4er','ttmeiju'];
    const pageURL = window.location.href;
    let sign;
    let cssStyle;
    let BleuButton;
    let buttParent;

    let toolbox = {

        addNewStyle() {
            if(sign === 'cloudPan'){return 0;}
            cssStyle = [
                '.btn_bleu{padding: 10px 25px;font-size: 16px;cursor: pointer;text-align: center;   text-decoration: none;outline: none;color: #fff;background-color: #008CBA;border: none;border-radius: 14px;display:block;margin:0 auto}',
                '.btn_bleu:hover{background-color: #008CEA}',
                '.btn_bleu:active{background-color: #008CEA;box-shadow: 0 5px #666;transform: translateY(4px);}'
            ];
            BleuButton = '<div><input type="button" class="btn_bleu" value="复制全部链接"></div>';
            cssStyle.forEach(function(value){
                GM_addStyle(value);
            });
        },

        getURLsign() {
            webName.forEach(function (value) {
                if (pageURL.search(value) >= 0) { sign = value }
            })
            if (sign == undefined) {
                //云盘界面
                sign = 'cloudPan';
            }
        },

        getButtonParent() {
            //公众号屏蔽
            let adshow = $("div.widget-weixin");
            if(adshow.length != 0){
                adshow.remove();
            }
            let box;
            switch(sign) {
                case 'meijutt':
                    $("div.widget-weixin").remove();
                    box = $("div.o_cn_r_box");
                    break;
                case '91mjw':
                    box = $(".down-list");
                    break;
                case '22tu':
                    box = $(".downurl.down-list");
                    break;
                case 'kpkuang':
                    box = $(".fed-down-item.fed-drop-item.fed-visible");
                    break;
                case 'mp4er':
                    box = $(".ui.middle.aligned.animated.list");
                    break;
                case 'ttmeiju':
                    box = $("div.box_bor3");
                    break;
                default:
                    break;
            }
            return box;
        },

        arryDel(arrold){
            var arr=[] ;
            arrold.forEach(function(value){
                if(arr.indexOf(value) == -1){
                    if(sign == 'kpkuang'){
                        value = decodeURIComponent(escape(window.atob(value.replace('data-clipboard-text="',''))));
                    }
                    arr.push(value);
                }
            })
            return arr;
        },

        getDownloadText(){
            let ulstr=buttParent.innerHTML;
            let reg = /magnet\:\?[^"]*|ed2k\:\/\/[^"]*|thunder\:\/\/[^"]*|data-clipboard-text="[^"]*/g;
            let s = ulstr.match(reg);
            return s == null ? s :this.arryDel(s);
        },

        findLinknode(buttdiv){
            buttParent = buttdiv
            if(sign == "meijutt"){
                for(let tabs of document.getElementsByClassName('tabs-list')){
                    if(tabs.getAttribute('style') == 'display: block;'||tabs.getAttribute('style') == null){
                        return tabs ;
                    }
                }
            }
            return buttParent;
        },

        //适配mp4er网站
        downloadTorrent(button){
            if(sign != "mp4er"){return 0;}
            $(button).attr('value','下载全部文件') ;
            $(buttParent).find("a").each(function(){this.click();});
        },
        sleep(time) {
            return new Promise((resolve) => setTimeout(resolve, time));
        },
        isHidden(el) {
            try {
                return el.offsetParent === null;
            } catch (e) {
                return false;
            }
        }
    }

    let linkHandler = {

        panListener(panInputSign,panBttonSign) {
            let password = GM_getValue('password');
            let maxTime = 10;
            let listener = setInterval(async() => {
                maxTime--;
                let panInput = document.querySelector(panInputSign);
                let panBtton = document.querySelector(panBttonSign);
                if (panInput &&!toolbox.isHidden(panInput)){

                    clearInterval(listener);

                    let lastValue = panInput.value;
                    panInput.value = password;
                    //Vue & React 触发 input 事件===》 可行
                    /*let event = new Event('input', {bubbles: true});
                    let tracker = panInput._valueTracker;
                    if (tracker) {
                        tracker.setValue(lastValue);
                    }
                    panInput.dispatchEvent(event);*/
                    //js原生触发===》可行
                    var evt = document.createEvent('HTMLEvents')
                    evt.initEvent('input', true, true)
                    panInput.dispatchEvent(evt)
                    //jquery触发===》不可行
                    //$(panInput).bind('input propertychange', function() {$(this).val(lastValue);});

                    await toolbox.sleep(1000); //1秒后点击按钮
                    panBtton.click();
                }
                else{
                    maxTime === 0 && clearInterval(listener);
                }
            }, 800);
        },

        autoOpenPan(){
            if(sign != 'cloudPan'){return 0;}
            let panInput,panBtton;
            if(pageURL.search('xunlei') >= 0){
                panInput='.pass-input-wrap .td-input__inner';
                panBtton='.pass-input-wrap .td-button';
            }
            if(pageURL.search('baidu') >= 0){
                panInput='#accessCode';
                panBtton='#submitBtn';
            }
            linkHandler.panListener(panInput,panBtton);
        },

        //适配meijutt网站
        fixPanButton(){
            if(sign != "meijutt"){return 0;}
            let option = { active: true, insert: true, setParent :true };
            $('.copy-pw').each(function(){
                $(this).attr('value','点击进入');
                $(this).attr('href',$(this).next().attr('href'));
                $(this).next().remove();
            })
            $('.copy-pw').on('click',function(){
                GM_setClipboard($(this).attr('data'), 'text');
                GM_setValue('password',$(this).attr('data'));
                //window.location.href = $(this).attr('href');
                GM_openInTab($(this).attr('href'), option);
            })
        },

        ButtonAddEvent(){
            $('.btn_bleu').on("click",function(){
                buttParent = toolbox.findLinknode(this.parentNode.parentNode);
                let arryAll = toolbox.getDownloadText();
                GM_setClipboard(arryAll, 'text');
                arryAll == null ? toolbox.downloadTorrent(this):arryAll;
            });
        },

        processButton() {
            if(sign === 'cloudPan'){return 0;}
            buttParent = toolbox.getButtonParent();
            buttParent.append(BleuButton);
            this.ButtonAddEvent();
            this.fixPanButton();//适配meijutt网站
        },

        init(){
            toolbox.getURLsign();
            toolbox.addNewStyle();
            this.processButton();
            this.autoOpenPan();
        },
    }

    linkHandler.init();
})();