MrCong全量加載

mrCong全量加載,啦啦啦

As of 05.04.2022. See апошняя версія.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         MrCong全量加載
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  mrCong全量加載,啦啦啦
// @author       LARA_SSR
// @match        https://mrcong.com/*/
// @exclude      https://mrcong.com/tag/*
// @exclude      https://mrcong.com/category/*
// @exclude      https://mrcong.com/sets/*
// @exclude      https://mrcong.com/top*/*
// @exclude      https://mrcong.com/tim-kiem/*
// @icon         
// @grant        none
// @license      MIT
// @require      https://cdn.staticfile.org/jquery/3.6.0/jquery.min.js
// @require      https://cdn.staticfile.org/viewerjs/1.10.4/viewer.min.js
// ==/UserScript==
let os = function () {
    let ua = navigator.userAgent, //获取浏览器UA
        isWindowsPhone = /(?:Windows Phone)/.test(ua),
        isSymbian = /(?:SymbianOS)/.test(ua) || isWindowsPhone,
        isAndroid = /(?:Android)/.test(ua),
        isFireFox = /(?:Firefox)/.test(ua),
        isChrome = /(?:Chrome|CriOS)/.test(ua),
        isTablet = /(?:iPad|PlayBook)/.test(ua) || (isAndroid && !/(?:Mobile)/.test(ua)) || (isFireFox && /(?:Tablet)/.test(ua)),
        isPhone = /(?:iPhone)/.test(ua) && !isTablet,
        isPc = !isPhone && !isAndroid && !isSymbian;
    return {
        isTablet: isTablet,
        isPhone: isPhone,
        isAndroid: isAndroid,
        isPc: isPc
    };
}();
if (os.isAndroid || os.isPhone) //判断是否Android或Phone
{
    // ==UserScript==
    // @name         MrCong全量加載
    // @namespace    http://tampermonkey.net/
    // @version      0.43
    // @description  mrCong全量加載,啦啦啦
    // @author       LARA_SSR
    // @match        https://mrcong.com/*/
    // @exclude      https://mrcong.com/tag/*
    // @exclude      https://mrcong.com/category/*
    // @exclude      https://mrcong.com/sets/*
    // @exclude      https://mrcong.com/top*/*
    // @exclude      https://mrcong.com/tim-kiem/*
    // @icon         
    // @grant        none
    // @license      MIT
    // @require      https://cdn.staticfile.org/jquery/3.6.0/jquery.min.js
    // @require      https://cdn.staticfile.org/viewerjs/1.10.4/viewer.min.js
    // ==/UserScript==

    (async function () {
        let addStyle = function (aCss) {
            let head = document.getElementsByTagName('head')[0];
            if (head) {
                let style = document.createElement('style');
                style.setAttribute('type', 'text/css');
                style.textContent = aCss;
                head.appendChild(style);
                return style;
            }
            return null;
        }
        let addScriptModule = function (aScript) {
            let head = document.getElementsByTagName('head')[0];
            if (head) {
                let script = document.createElement('script');
                script.setAttribute('type', 'module');
                script.textContent = aScript;
                head.appendChild(script);
                return script;
            }
            return null;
        }
        let addScript = function (aScript) {
            let head = document.getElementsByTagName('head')[0];
            if (head) {
                let script = document.createElement('script');
                script.setAttribute('type', 'text/javascript');
                script.textContent = aScript;
                head.appendChild(script);
                return script;
            }
            return null;
        }

        async function addScriptCss() {
            let fancyboxLink = "https://cdn.jsdelivr.net/npm/@fancyapps/[email protected]/dist/fancybox.css";
            let fancyboxData = await Get(fancyboxLink);
            addStyle(fancyboxData);
        }
        // let addScriptCssResult = await addScriptCss();
        addScriptCss();
        let open = 'Default';
        switch (open) {
            case 'Fullscreen':
                addStyle(`
            a[data-fancybox] img{cursor:zoom-in}
            .fancybox__container{--carousel-button-bg:rgb(0 0 0 / 44%);--carousel-button-svg-width:24px;--carousel-button-svg-height:24px;--carousel-button-svg-stroke-width:2.5;--carousel-button-svg-filter:none}
            .fancybox__nav{--carousel-button-svg-width:22px;--carousel-button-svg-height:22px;--carousel-button-svg-stroke-width:3}
            .fancybox__nav .carousel__button.is-prev{left:30px}
            .fancybox__nav .carousel__button.is-next{right:30px}
            .carousel__button.is-close{top:30px;right:30px}
            .fancybox__slide{padding:0}
            .fancybox__thumbs{position:absolute;bottom:0;left:0;right:0;z-index:10}
            .fancybox__thumbs .carousel__slide{padding:20px 10px;overflow:visible}
            .fancybox__thumb{border-radius:6px;box-shadow:0 4px 6px -1px rgba(0,0,0,0.3),0 2px 4px -1px rgba(0,0,0,0.26)}
            .is-nav-selected .fancybox__thumb{transform:scale(1.25)}
            .is-nav-selected .fancybox__thumb::after{display:none}
        `);
                addScriptModule(`
            import{Fancybox}from"https://cdn.jsdelivr.net/npm/@fancyapps/ui/dist/fancybox.esm.js";Fancybox.bind('[data-fancybox="images"]',{Toolbar:false,animated:false,dragToClose:false,showClass:false,hideClass:false,closeButton:"top",Image:{click:"close",wheel:"slide",zoom:false,fit:"cover",},Thumbs:{minScreenHeight:0,},});
        `);
                break;
            case 'Default':
                addStyle(`
            a[data-fancybox] img{cursor:zoom-in;}
        `);
                addScriptModule(`
            import{Fancybox}from"https://cdn.jsdelivr.net/npm/@fancyapps/ui/dist/fancybox.esm.js";Fancybox.bind('[data-fancybox="images"]',{Thumbs:{Carousel:{fill:false,center:true,},},});
        `);
                break;
            case 'Background':
                addStyle(`
            a[data-fancybox] img{cursor:zoom-in;}.fancybox__backdrop::after{content:"";position:absolute;width:10%;height:10%;filter:blur(2px);left:50%;top:50%;transform:scale(11);opacity:0.3;background-image:var(--bg-image);background-size:cover;background-repeat:no-repeat;background-position:center center;}.fancybox__container{--fancybox-bg:#000;--fancybox-thumbs-width:48px;--fancybox-thumbs-ratio:1;--carousel-button-bg:rgb(91 78 76 / 74%);--carousel-button-svg-width:24px;--carousel-button-svg-height:24px;--carousel-button-svg-stroke-width:2.5;}.fancybox__nav{--carousel-button-svg-width:24px;--carousel-button-svg-height:24px;}.fancybox__nav .carousel__button.is-prev{left:20px;}.fancybox__nav .carousel__button.is-next{right:20px;}.carousel__button.is-close{right:auto;top:20px;left:20px;}.fancybox__slide{padding:8px 88px;}.fancybox__thumbs .carousel__slide{padding:8px 8px 16px 8px;}.is-nav-selected::after{display:none;}.fancybox__thumb{border-radius:6px;opacity:0.4;}.fancybox__thumb:hover,.is-nav-selected .fancybox__thumb{border-radius:6px;opacity:1;}.is-nav-selected .fancybox__thumb::after{display:none;}
        `)
                addScriptModule(`
            import{Fancybox}from"https://cdn.jsdelivr.net/npm/@fancyapps/ui/dist/fancybox.esm.js";Fancybox.bind('[data-fancybox="images"]',{dragToClose:false,Toolbar:false,closeButton:"top",Image:{zoom:false,},on:{initCarousel:(fancybox)=>{const slide=fancybox.Carousel.slides[fancybox.Carousel.page];fancybox.$container.style.setProperty("--bg-image",\`url("\${slide.$thumb.src}")\`)},"Carousel.change":(fancybox,carousel,to,from)=>{const slide=carousel.slides[to];fancybox.$container.style.setProperty("--bg-image",\`url("\${slide.$thumb.src}")\`)},},});
        `);
                break;
            case 'FollowCursor':
                addStyle(`
            a[data-fancybox]img{cursor:zoom-in;}.fancybox__container{--fancybox-color:#999;--fancybox-bg:#fff;--carousel-button-svg-width:32px;--carousel-button-svg-height:32px;--carousel-button-svg-stroke-width:1.2;--carousel-button-svg-filter:none;}.fancybox__nav{--carousel-button-svg-width:36px;--carousel-button-svg-height:36px;--carousel-button-svg-stroke-width:1;}.has-image[data-image-fit="contain-w"]{padding:0;overflow:hidden;}
        `)
                addScriptModule(`
            import{Fancybox}from"https://cdn.jsdelivr.net/npm/@fancyapps/ui/dist/fancybox.esm.js";Fancybox.bind('[data-fancybox="images"]',{animated:false,showClass:false,hideClass:false,dragToClose:false,closeButton:"top",Thumbs:false,Toolbar:false,Carousel:{Panzoom:{touch:false,},},Image:{zoom:false,wheel:false,click:"close",fit:"contain-w",},on:{ready:(fancybox,slide)=>{fancybox.clientY=(fancybox.options.event&&fancybox.options.event.clientY)||0;fancybox.$container.addEventListener("mousemove",(e)=>{fancybox.clientY=e.clientY;fancybox.trigger("mousemove");});},"done Carousel.change":(fancybox)=>{fancybox.trigger("mousemove");},mousemove:(fancybox)=>{const slide=fancybox.getSlide();if(!slide||!slide.$image||slide.state!=="done"){return;}
            const $el=slide.$el;const imageHeight=slide.$image.clientHeight;const style=window.getComputedStyle($el);const paddingTop=parseFloat(style.paddingTop);const paddingBottom=parseFloat(style.paddingBottom);const viewportHeight=$el.clientHeight-paddingTop-paddingBottom;const pointerY=fancybox.clientY-paddingTop;$el.scrollTop=(pointerY*(imageHeight-viewportHeight))/viewportHeight;},},});
        `);
                break;
            case 'ClassicDesign':
                addStyle(`
            a[data-fancybox] img{cursor:zoom-in;}.fancybox__container{--fancybox-bg:rgba(17,6,25,0.85);}.fancybox__container .fancybox__content{box-sizing:content-box;padding:1rem;background:#fff;border-radius:6px;color:#374151;box-shadow:0 8px 23px rgb(0 0 0 / 50%);}.fancybox__caption{max-width:80%;--fancybox-opacity:1;}
        `)
                addScriptModule(`
            import{Fancybox}from"https://cdn.jsdelivr.net/npm/@fancyapps/ui/dist/fancybox.esm.js";Fancybox.bind('[data-fancybox="images"]',{Thumbs:false,Toolbar:false,Image:{zoom:false,click:false,wheel:"slide",},});
        `);
                break;
        };
        //获取页数
        let paginationClass = "div .page-link";
        let length = 0;
        let paginationExist = false;
        $(paginationClass).each(function () {
            if (paginationExist == true) {
                return false;
            }
            length = $(this).find("a").length;
            paginationExist = true;
            //console.log(linkArr);
            console.log("页数:" + length);
        });

        //标题
        addStyle(`
        .titleHrefs,.postTagHrefs {
            padding:1px 5px;
        }
        #title_info {
            color:pink;
            border:1px solid;
            border-color:rgba(0,0,0,0);
            border-bottom-color:pink;
        }
        #separate {
            color:white;
        }
        #downHref>a {
            color:pink;
            border:1px solid;
            border-color:rgba(0,0,0,0);
            border-bottom-color:#815c94;
        }
        .titleHrefs>div,.postTagHrefs>div {
            display:inline;
        }
        #spanitemdiv {
            color:#FFFAF0;
        }
        #spanitem {
            color:#FFFAF0;
        }
    `);
        let titleHrefs = $("<div class = titleHrefs></div>");
        let postTagHrefs = $("<div class = postTagHrefs></div>");

        await new Promise(function (resolve) {
            $("#crumbs a").each(function (index, value) {
                let hrefDiv = $("<div class = hrefDiv></div>")
                let title = $(this).attr("id", "title_info");
                hrefDiv.append(title)
                titleHrefs.append(hrefDiv);
                // console.log(title);
                let p3 = $("<div id = separate>\xa0/\xa0</div>");
                titleHrefs.append(p3);
            });
            $(".post-tag a").each(function (index, value) {
                let hrefDiv = $("<div class = hrefDiv></div>")
                let title = $(this).attr("id", "title_info");
                hrefDiv.append(title)
                postTagHrefs.append(hrefDiv);
                // console.log(title);
                let p3 = $("<div id = separate>\xa0/\xa0</div>");
                postTagHrefs.append(p3);
            });
            resolve();
        });

        let password = $("strong+input[value]").attr('value');
        console.log("Password: " + password);

        let patt = /(?<=Dung lượng: )(\d+|([1-9]\d*\.?\d+))[A-Za-z]*(B|b)/g
        let inerBoxStr = $(".box-inner-block").text()
        // console.log(inerBoxStr);
        let imgSize = inerBoxStr.match(patt)[0];
        console.log(imgSize);
        let downHref;
        let p3;
        //let p3 =$("<b id = separate>\xa0/\xa0</b>")
        $("p[style] a").each(function (index, value) {

            downHref = $("<div id = downHref></div>");
            let itemTitleHref = $("<a>图片下载</a>").attr("href", $(this)[0].href).text(`图片下载链接[ ${index+1} ]`);

            downHref.append(itemTitleHref);
            titleHrefs.append(downHref);
            p3 = $("<div id = separate>\xa0/\xa0</div>");
            downHref.after(p3);
        })
        //titleHrefs.append(p3)
        p3 = $("<div id = separate>\xa0/\xa0</div>");
        titleHrefs.append($("<div id = spanitem></div>").text(`解压密码: (${password})`))
        p3 = $("<div id = separate>\xa0/\xa0</div>");
        titleHrefs.append(p3);
        titleHrefs.append($("<div id = spanitem></div>").text(`图片大小: (${imgSize})`))
        p3 = $("<div id = separate>\xa0/\xa0</div>");
        titleHrefs.append(p3);
        let SpanItemDiv = $("<div id = spanitemdiv></div>")
        let spanItem = $("span[itemprop]").text();
        // console.log(spanItem);
        SpanItemDiv.append(spanItem);
        titleHrefs.append(SpanItemDiv);


        addStyle(`
        ul li {
            list-style-type:none;
        }
        body {
            background:#4a4035;
            // font-family:-apple-system,BlinkMacSystemFont,Tahoma,Arial,"Hiragino Sans GB","Microsoft YaHei",sans-serif;
            font-family: fantasy,sans-serif;
        }
        #viewer {
            padding:0px;
            margin:0px;
        }
        .imgbox {
            width:100%;
            position:relative;
            overflow:hidden;
            box-sizing:border-box;
            padding:1px;
        }
        .imgnum {
            position:absolute;
            font-size:90%;
            left:5px;
            top:5px;
            background:#17A1FF;
            background:rgba(23,161,255,0.5);
            z-index:100;
            padding:0px 5px 1px 5px;
            color:#f9f9f9;
            color:rgba(249,249,249,1);
            border-radius:2px;
        }
        .imgs {
            width:100%;
            float:left;
            border-radius:4px;
        }
    `);

        'use strict';
        $("body").empty();
        let i = 1;
        let str3 = self.location.href;
        let newStr = str3.replace(/-anh.+/g, "");
        let link = "";
        let viewer2 = $('<ul id ="viewer"></ul>');
        $("body").append(viewer2);
        viewer2.append(titleHrefs);
        let n = 0;
        do {
            link = newStr + "-anh/" + i;
            let data = await Get(link);

            let image = $(".content img", data);
            image.each(function (index, item) {
                n++;
                let imgli = $('<li class = "imgbox"></li>');
                let imageItem = '<a data-fancybox=\"images\" href=\"' + $(this)[0].src + '\"><img class=\"imgs\" src=\"' + $(this)[0].src + '\" ></a>';

                //序号
                let stringNum = "<div class = 'imgnum'>{imgnum}</div>";
                let newStringNum = stringNum.replace('{imgnum}', `${n}`)
                imgli = imgli.prepend($(newStringNum));

                imgli = imgli.append(imageItem);
                viewer2.append(imgli)
            });

            i = i + 1;
            if (i === (length + 2)) {
                $(document).ready(function () {
                    $("#viewer").after(postTagHrefs);
                });
            }
        } while (i < length + 2);

        // setTimeout(() => {
        //     let viewer3 = new Viewer(document.getElementById('viewer'), {
        //         //inline:true,
        //         viewed() {}
        //     });
        // }, 3000);
        // Your code here...

        let imgCount = $("#viewer img").length;
        console.log("imgCount: " + imgCount);

        $(".imgnum").each(function (index, value) {
            if (index < imgCount) {
                // console.log($(this));
                $(this).text(`[${index+1}/${imgCount}]`)
            } else {
                return false;
            }
        })

        //删除标题最后一个"/"
        $(document).ready(function () {
            // $(".titleHrefs div").eq(-1).remove();

            $(".postTagHrefs #separate").eq(-1).remove();
        });

        function Get(link) {
            return new Promise(function (resolve) {
                $.get(link, data => {
                    resolve(data);
                })
            });
        }

    })();
}