RandomSexyPicParser

Random Sexy Pictures Parser

// ==UserScript==
// @name         RandomSexyPicParser
// @name:zh-TW   軟瑟盤
// @name:ja      RandomSexyPicParser
// @namespace    hoothin
// @version      1.3.19
// @description        Random Sexy Pictures Parser
// @description:zh-TW  隨機色圖
// @description:ja     ランダムセクシー画像パーサー
// @author       hoothin
// @match        https://api.lolicon.app/setu/v2*
// @match        https://api.nyan.xyz/httpapi/sexphoto*
// @match        https://huanmengii.xyz/ZY/aCOS/cos*
// @match        https://api.uomg.com/api/rand.img3*
// @match        https://api.vvhan.com/api/tao*
// @match        https://www.hlapi.cn/api/mjx*
// @match        https://3650000.xyz/api/?*
// @match        *://*/*
// @icon         
// @grant        GM_addStyle
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_xmlhttpRequest
// @grant        GM_registerMenuCommand
// @run-at       document-idle
// @license      MIT
// ==/UserScript==
if (window.top != window.self) {
    return;
}

(function() {
    'use strict';
    var setuConfig={
        "api.lolicon.app":{
            include: /setu\/v2/i,
            name:"Lolicon ACG SexyPic",
            url:"https://api.lolicon.app/setu/v2?r18=1&num=10",
            luckyUrl:["https://api.lolicon.app/setu/v2?r18=0&num=5",
                     "https://api.lolicon.app/setu/v2?r18=1&num=5",
                     "https://api.lolicon.app/setu/v2?r18=2&num=5"],
            run:()=>{
                var searchNum=getSearchParam("num");
                var leftNum=searchNum;
                if(jsonData != "Forbidden"){
                    let datas=jsonData.data;
                    datas.forEach(function(data){
                        leftNum--;
                        let img=createImg(data.urls?data.urls.original:data.url);
                        img.title=data.title+" - "+data.author;
                    });
                }else{
                    location.href=curConfig.url;
                }
                processByTime(leftNum,loadNum=>{
                    GM_xmlhttpRequest({
                        method: 'GET',
                        url: curConfig.url.replace("num=5","num="+loadNum),
                        timeout:15000,
                        onload: function(result) {
                            let datas=JSON.parse(result.responseText).data;
                            datas.forEach(function(data){
                                let img=createImg(data.urls?data.urls.original:data.url);
                                img.title=data.title+" - "+data.author;
                            });
                        }
                    });
                },5,1000);
            },
            getSearch:(param)=>{
                return `v2?r18=${param.r18}&num=${param.num}`;
            },
            initSearch:()=>{
                var searchNum=getSearchParam("num");
                var searchR18=getSearchParam("r18");
                numInput.value=searchNum;
                r18Check.checked=searchR18==1||searchR18==2;
                sfwCheck.checked=searchR18==0||searchR18==2;
            }
        },
        "api.nyan.xyz":{
            hide: true,
            include: /httpapi\/sexphoto/i,
            name:"Nyan ACG SexyPic",
            url:"https://api.nyan.xyz/httpapi/sexphoto/?r18=true&num=10",
            luckyUrl:["https://api.nyan.xyz/httpapi/sexphoto/?r18=true&num=5",
                     "https://api.nyan.xyz/httpapi/sexphoto/?r18=false&num=5"],
            run:()=>{
                var searchNum=getSearchParam("num");
                var leftNum=searchNum;
                var urls=jsonData.data.url;
                if(!urls instanceof Array){
                    urls=[urls];
                }
                urls.forEach(function(data){
                    leftNum--;
                    createImg(data);
                });
                processByTime(leftNum,loadNum=>{
                    GM_xmlhttpRequest({
                        method: 'GET',
                        url: curConfig.url.replace("num=5","num="+loadNum),
                        timeout:15000,
                        onload: function(result) {
                            urls=JSON.parse(result.responseText).data.url;
                            urls.forEach(function(data){
                                createImg(data);
                            });
                        }
                    });
                },5,1000);
            },
            getSearch:(param)=>{
                return `?r18=${param.r18==1?"true":"false"}&num=${param.num}`;
            },
            initSearch:()=>{
                var searchNum=getSearchParam("num");
                var searchR18=getSearchParam("r18");
                numInput.value=searchNum;
                r18Check.checked=searchR18=="true";
                sfwCheck.checked=searchR18=="false";
            }
        },
        "buyersShow":{
            include: /api\/(rand|tao|mjx1|taobaoBuyerShow)/i,
            name:"Taobao Buyers Show",
            urls:["https://api.uomg.com/api/rand.img3?format=json&num=15",
                 "https://api.suxun.site/api/tao?type=json&num=15",
                 "https://api.03c3.cn/api/taobaoBuyerShow?type=json&num=15"],
            run:()=>{
                r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
                var searchNum=getSearchParam("num");
                processByTime(searchNum,loadNum=>{
                    for(let i=0;i<loadNum;i++){
                        createImg(location.href.replace(/1?\?.*/,"?")+"r="+Math.random());
                    }
                },5,1000);
            },
            getSearch:(param)=>{
                return location.href.replace(/\d+$/,"")+param.num;
            },
            initSearch:()=>{
                var searchNum=getSearchParam("num");
                numInput.value=searchNum;
            }
        },
        "huanmengii.xyz":{
            hide: true,
            include: /ZY\/aCOS\/cos/i,
            name:"Cosplay Show",
            url:"https://huanmengii.xyz/ZY/aCOS/cos/?type=json&num=15",
            run:()=>{
                r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
                var searchNum=getSearchParam("num");
                processByTime(searchNum,loadNum=>{
                    for(let i=0;i<loadNum;i++){
                        GM_xmlhttpRequest({
                            method: 'GET',
                            url: curConfig.url+"&"+Math.random(),
                            timeout:15000,
                            onload: function(result) {
                                var curUrl=JSON.parse(result.responseText).pic;
                                createImg(curUrl);
                            }
                        });
                    }
                },5,1000);
            },
            getSearch:(param)=>{
                return "?type=json&num="+param.num;
            },
            initSearch:()=>{
                var searchNum=getSearchParam("num");
                numInput.value=searchNum;
            }
        },
        "3650000.xyz":{
            include: /\/api\/\?type=json/i,
            name:"3650000",
            url:"https://3650000.xyz/api/?type=json&mode=7&num=6",
            luckyUrl:["https://3650000.xyz/api/?type=json&num=6",
                     "https://3650000.xyz/api/?type=json&mode=1&num=6",
                     "https://3650000.xyz/api/?type=json&mode=2&num=6",
                     "https://3650000.xyz/api/?type=json&mode=3&num=6",
                     "https://3650000.xyz/api/?type=json&mode=5&num=6",
                     "https://3650000.xyz/api/?type=json&mode=6&num=6",
                     "https://3650000.xyz/api/?type=json&mode=7&num=6",
                     "https://3650000.xyz/api/?type=json&mode=8&num=6",
                     "https://3650000.xyz/api/?type=json&mode=9&num=6"],
            run:()=>{
                r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
                var searchNum=getSearchParam("num");
                var searchMode=getSearchParam("mode");
                processByTime(searchNum,loadNum=>{
                    for(let i=0;i<loadNum;i++){
                        GM_xmlhttpRequest({
                            method: 'GET',
                            url: `${curConfig.url}&mode=${searchMode}&${Math.random()}`,
                            timeout:15000,
                            onload: function(result) {
                                var curUrl=JSON.parse(result.responseText).url;
                                createImg(curUrl);
                            }
                        });
                    }
                },5,1000);
            },
            getSearch:(param)=>{
                return location.pathname+`?type=json&mode=${param.mode}&num=${param.num}`;
            },
            initSearch:()=>{
                var searchNum=getSearchParam("num");
                var searchMode=getSearchParam("mode");
                var modeObj=[
                    ["Public",""],
                    ["Weibo","1"],
                    ["Instagram","2"],
                    ["Cosplay","3"],
                    ["Mtcos","5"],
                    ["Mtcos2","6"],
                    ["Legs","7"],
                    ["MoreCoser","8"],
                    ["Tuwan","9"]
                ];
                modeObj.forEach(item=>{
                    var option=document.createElement("option");
                    option.value=item[1];
                    option.innerText=item[0];
                    if(item[1]==searchMode){
                        option.selected=true;
                    }
                    modeSelect.appendChild(option);
                });
                modeSelect.style.display="inline";
                numInput.value=searchNum;
            }
        },
        "api.uomg.com":"buyersShow",
        "api.vvhan.com":"buyersShow",
        "www.hlapi.cn":"buyersShow",
        "api.ghser.com":"buyersShow",
        "api.03c3.cn":"buyersShow",
        "api.suxun.site":"buyersShow"
    };
    var customRule=GM_getValue("RSPrules") || {};
    var customRuleArr=[];
    for(var j in customRule){
        let href=customRule[j];
        customRuleArr.push(href);
    }
    GM_registerMenuCommand("I am feeling lucky", ()=>{
        var luckyUrls=[],targetUrl;
        for(var i in setuConfig){
            let sc=setuConfig[i];
            if(sc.hide){
                continue;
            }else if(sc.luckyUrl){
                luckyUrls=luckyUrls.concat(sc.luckyUrl);
            }else if(sc.urls){
                luckyUrls=luckyUrls.concat(sc.urls);
            }else if(sc.url){
                luckyUrls.push(sc.url);
            }
        }
        luckyUrls=luckyUrls.concat(customRuleArr);
        var randomIndex=Math.floor(Math.random()*luckyUrls.length);
        targetUrl=luckyUrls[randomIndex];
        location.href=targetUrl;
    });
    const _unsafeWindow = (typeof unsafeWindow == 'undefined') ? window : unsafeWindow;
    const escapeHTMLPolicy = (_unsafeWindow.trustedTypes && _unsafeWindow.trustedTypes.createPolicy) ? _unsafeWindow.trustedTypes.createPolicy('rspp_default', {
        createHTML: (string, sink) => string
    }) : null;

    function createHTML(html) {
        return escapeHTMLPolicy ? escapeHTMLPolicy.createHTML(html) : html;
    }
    if (location.href.indexOf("randomsexypicparser") != -1) {
        GM_addStyle(".discussion-rating{display:none}");
    }
    var curConfig=setuConfig[document.domain],jsonData,hasFloatImg=false,grabed=false,oClient;
    if(curConfig){
        if(!curConfig.run){
            curConfig=setuConfig[curConfig];
        }
        if(curConfig.include && !curConfig.include.test(location.href)){
            curConfig=false;
        }
    }
    if(!curConfig){
        let currentParsing=customRule[document.domain+location.pathname];
        if(!currentParsing){
            GM_registerMenuCommand("Parse current api", customSet);
            return;
        }else{
            GM_registerMenuCommand("Stop parse api", () => {
                delete customRule[document.domain+location.pathname];
                GM_setValue("RSPrules", customRule);
                location.reload();
            });
            curConfig={run:()=>{
                var searchNum=getSearchParam("num");
                var leftNum=searchNum;
                r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
                let parsePics=(data)=>{
                    let picUrls=[],urlReg=/(https?|ftp|file):\/\/[\-A-Za-z0-9\+&@#/%?=~_\|!:,\.;]+[\-A-Za-z0-9\+&@#/%=~_\|]/g;
                    if(typeof data == "string"){
                        picUrls=data.match(urlReg);
                    }else{
                        let checkJson=obj=>{
                            for(let i in obj){
                                if(typeof obj[i] == "string"){
                                    let pics=obj[i].match(urlReg);
                                    if(pics)picUrls=picUrls.concat(pics);
                                }else checkJson(obj[i]);
                            }
                        };
                        checkJson(data);
                    }
                    if(picUrls){
                        picUrls=picUrls.filter((item, index) => picUrls.indexOf(item) === index);
                        picUrls.forEach(url=>{
                            leftNum--;
                            createImg(unescape(url));
                        });
                    }
                }
                parsePics(jsonData);
                processByTime(leftNum||1, loadNum=>{
                    let href=location.href.replace(/num=\d+(&time=\d+)?/,"num="+loadNum+"&time="+Date.now()),postParams=href.match(/#p{(.*)}/);
                    if(postParams){
                        postParams=postParams[1];
                        href=href.replace(/#p{.*/,"");
                    }
                    GM_xmlhttpRequest({
                        method: postParams?'POST':'GET',
                        data: postParams,
                        headers: {
                            'Referer': location.href,
                            "Content-Type": (postParams ? "application/x-www-form-urlencoded" : "text/html") + ";charset=" + (document.characterSet || document.charset || document.inputEncoding),
                        },
                        url: href,
                        timeout:15000,
                        onload: function(result) {
                            var parseData;
                            try{
                                parseData=JSON.parse(result.responseText);
                                console.log(parseData);
                            }catch(e){
                                parseData=result.responseText;
                            }
                            parsePics(parseData);
                        }
                    });
                }, (leftNum < searchNum - 1 ? 5 : 1), 1000);
            },
            getSearch:(param)=>{
                var href=location.href;
                if(/\bnum=/.test(href)){
                    href=href.replace(/\bnum=\d+(&time=\d+)?/,"num="+param.num+"&time="+Date.now());
                }else{
                    if(href.indexOf("?")==-1){
                        if(href.indexOf("#")==-1){
                            href+="?num="+param.num+"&time="+Date.now();
                        }else{
                            href=href.replace("#","?num="+param.num+"&time="+Date.now()+"#");
                        }
                    }else{
                        href+="&num="+param.num+"&time="+Date.now();
                    }
                }
                return href;
            },
            initSearch:()=>{
                var searchNum=getSearchParam("num");
                numInput.value=searchNum;
            }};
        }
    }
    document.title=curConfig.name?curConfig.name:"Random Sexy Pictures";
    try{
        var firstText = "";
        for (var i = 0; i < document.body.childNodes.length; i++) {
            var curNode = document.body.childNodes[i];
            if (curNode.nodeType == 1 || curNode.nodeName == "PRE") {
                firstText = curNode.nodeValue || curNode.innerText;
                if (firstText) break;
            }
        }
        if(firstText)jsonData=JSON.parse(firstText);
    }catch(e){
        console.log(e);
        jsonData=firstText;
    }
    document.body.innerHTML=createHTML("");
    var imgCon=document.createElement("div");
    var btns=document.createElement("div");
    var numInput=document.createElement("input");
    var r18Check=document.createElement("input");
    var r18CheckLabel=document.createElement("label");
    var sfwCheck=document.createElement("input");
    var sfwCheckLabel=document.createElement("label");
    var modeSelect=document.createElement("select");
    var submit=document.createElement("button");
    var referrerMeta=document.createElement("meta");
    var viewportMeta=document.createElement("meta");
    var overMask=document.createElement("div");
    var homepage=document.createElement("a");
    var lightBtn=document.createElement("span");
    for(var name in setuConfig){
        var config=setuConfig[name];
        if(config.hide || !config.name)continue;
        var siteA=document.createElement("a");
        var url=config.url;
        if(config.urls){
            var randomIndex=Math.floor(Math.random()*config.urls.length);
            url=config.urls[randomIndex];
            config.url=url;
        }
        siteA.href=url;
        siteA.innerText=config.name;
        btns.appendChild(siteA);
    }
    if(customRuleArr.length){
        var otherSiteA=document.createElement("a");
        otherSiteA.href=customRuleArr[Math.floor(Math.random()*customRuleArr.length)];
        otherSiteA.innerText="Other";
        btns.appendChild(otherSiteA);
    }
    btns.appendChild(numInput);
    btns.appendChild(r18Check);
    btns.appendChild(r18CheckLabel);
    btns.appendChild(sfwCheck);
    btns.appendChild(sfwCheckLabel);
    btns.appendChild(modeSelect);
    btns.appendChild(submit);
    btns.appendChild(homepage);
    btns.appendChild(lightBtn);
    overMask.className="over-mask";
    imgCon.appendChild(overMask);
    referrerMeta.name="referrer";
    referrerMeta.content="never";
    document.head.appendChild(referrerMeta);
    viewportMeta.name="viewport";
    viewportMeta.content="width=device-width, initial-scale=1";
    document.head.appendChild(viewportMeta);

    curConfig.run();
    if(curConfig.initSearch)curConfig.initSearch();

    function sleep(fn,param,time) {
        return new Promise((resolve) => {
            setTimeout(() => resolve(fn(param)), time)
        })
    }
    async function processByTime(num,fn,limit,time) {
        while(num>0){
            var loadNum=limit;
            if(num<limit)loadNum=num;
            num-=loadNum;
            await sleep(fn,loadNum,time);
        }
    }

    overMask.onclick=e=>{
        if(hasFloatImg){
            restoreImg(hasFloatImg);
        }
    };

    function mousedownHandler(e){
        let img=e.target;
        img.addEventListener("mouseup",mouseupHandler);
        img.addEventListener("mousemove",mousemoveHandler);
        img.style.cursor="grabbing";
        oClient={
            x:window.scrollX+e.clientX,
            y:window.scrollY+e.clientY,
        };
        e.stopPropagation();
        e.preventDefault();
        e.returnValue=false;
    }
    function mousemoveHandler(e){
        let img=e.target;
        grabed=true;
        window.scrollTo(oClient.x-e.clientX, oClient.y-e.clientY);
    }
    function mouseupHandler(e){
        let img=e.target;
        img.removeEventListener("mouseup",mouseupHandler);
        img.removeEventListener("mousemove",mousemoveHandler);
        img.style.cursor="grab";
    }
    function grabHandler(img,add){
        if(add){
            img.addEventListener("mousedown",mousedownHandler);
        }else{
            img.removeEventListener("mousedown",mousedownHandler);
        }
    }

    function restoreImg(img){
        hasFloatImg=false;
        img.style.zIndex=0;
        img.style.bottom="";
        img.style.width="100%";
        img.style.position="";
        img.style.margin="";
        document.body.style.overflow="";
        imgCon.style.maxHeight="";
        imgCon.style.maxWidth="";
        overMask.style.display="none";
        overMask.style.opacity=0;
        img.className="list-show";
        grabHandler(img,false);
        img.style.cursor="";
        img.scrollIntoView({ block: "center", inline: "center" });
    }

    function createImg(url){
        let img=document.createElement("img");
        img.onerror=e=>{
            img.style.display="none";
        };
        img.src=url;
        img.className="list-show";
        img.style.width="100%";
        img.onclick=()=>{
            if(grabed){
                grabed=false;
                return;
            }
            window.scrollTo(0,0);
            var de=document.documentElement;
            var body=document.body;
            var backCompat=document.compatMode=='BackCompat';
            var windowSize={
                h: backCompat ? body.clientHeight : de.clientHeight,
                w: backCompat ? body.clientWidth : de.clientWidth,
            };
            if(img.style.zIndex==2){
                restoreImg(img);
            }else if(img.style.zIndex==1){
                img.style.bottom="";
                img.style.width="";
                img.style.maxWidth="";
                img.style.maxHeight="";
                img.style.zIndex=2;
                img.style.cursor="grab";
                grabHandler(img,true);
                document.body.style.overflow="";
                imgCon.style.maxWidth="100vw";
                imgCon.style.maxHeight="100vh";
            }else{
                if(hasFloatImg)return;
                hasFloatImg=img;
                document.body.style.overflow="hidden";
                img.style.bottom=0;
                if(img.naturalWidth>windowSize.w || img.naturalHeight>windowSize.h){
                    img.style.zIndex=1;
                    img.style.maxWidth="99%";
                    img.style.maxHeight="99%";
                }else{
                    img.style.zIndex=2;
                    img.style.maxWidth="";
                    img.style.maxHeight="";
                }
                img.style.width="";
                img.style.position="absolute";
                img.style.margin="auto";
                overMask.style.display="block";
                img.className="";
                setTimeout(()=>{
                    overMask.style.opacity=1;
                }, 0);
            }
        };
        imgCon.appendChild(img);
        return img;
    }

    function getSearchParam(name){
        let reg = new RegExp("(&|^)" + name + "=([^&]*)(&|$)", "i");
        let r = window.location.search.substr(1).match(reg);
        if (r != null) {
            return decodeURIComponent(r[2]);
        };
        return "";
    }

    function submitParam(){
        var num=numInput.value,mode;
        if(modeSelect.options.length>0){
            mode=modeSelect.options[modeSelect.selectedIndex].value;
        }
        var r18=2;
        if(sfwCheck.checked && !r18Check.checked){
            r18=0;
        }else if(!sfwCheck.checked && r18Check.checked){
            r18=1;
        }
        if(numInput.value != ""){
            location.href=curConfig.getSearch({"r18":r18, "num":num, "mode":mode});
        }else{
            location.reload();
        }
    }

    function customSet(){
        if(window.confirm("Parse current api?")){
            customRule[document.domain+location.pathname]=location.href;
            GM_setValue("RSPrules", customRule);
            location.reload();
        }
    }

    GM_addStyle(`
    @media screen and (min-width: 1024px) {
      .img-con{
        column-count: 5;
        -moz-column-count: 5;
        -webkit-column-count: 5;
      }
      .img-con>img{
        min-height: 250px;
      }
    }
    @media screen and (max-width: 1024px) {
      .img-con{
        column-count: 2;
        -moz-column-count: 2;
        -webkit-column-count: 2;
      }
      .img-con>img{
        min-height: 50px;
      }
    }
    body{
      background: black;
      scrollbar-width: none;
    }
    body::-webkit-scrollbar {
      width: 0 !important;
      height: 0 !important;
    }
    .btns>select{
      display: none;
      height: 29px;
      border-radius: 3px 0 0 3px;
      -moz-border-radius: 3px 0 0 3px;
      -webkit-border-radius: 3px 0 0 3px;
      -ms-border-radius: 3px 0 0 3px;
      -o-border-radius: 3px 0 0 3px;
      border: none;
      color: #cacaca;
      background-color: #363636;
      font-size: 14px;
      outline: 0;
      padding: 2px 5px;
      vertical-align: top;
    }
    .over-mask{
      display: none;
      opacity: 0;
      width: 100%;
      height: 100%;
      background-color: #000000e6;
      position: fixed;
      z-index: 1;
      top: 0;
      left: 0;
      transition: opacity .3s ease-in-out;
      -moz-transition: opacity .3s ease-in-out;
      -o-transition: opacity .3s ease-in-out;
      -webkit-transition: opacity .3s ease-in-out;
    }
    .list-show:hover,.list-show.hover{
      opacity: 1;
      transform: scale(1.05);
    }
    .list-show{
      opacity: 0.6;
      transition: opacity .3s ease-in-out, transform .3s;
      -moz-transition: opacity .3s ease-in-out, transform .3s;
      -webkit-transition: opacity .3s ease-in-out, transform .3s;
    }
    .img-con{
        overflow-x: hidden;
        overflow: auto;
        width: 100%;
        min-height: calc(100vh - 70px);
        display: block;
        scrollbar-width: none;
    }
    .img-con::-webkit-scrollbar {
      width: 0 !important;
      height: 0 !important;
    }
    .img-con>img{
      -webkit-column-break-inside: avoid;
      break-inside: avoid;
      float: left;
      margin-bottom: 15px;
      margin-right: 15px;
      overflow: hidden;
      position: relative;
      top: 0;
      left: 0;
      right: 0;
      background: url() no-repeat center center;
    }
    .btns{
      padding: 10px 0;
      text-align: center;
      line-height: 30px;
      position: fixed;
      z-index: 1;
      width: 100%;
      top: 0;
      left: 0;
      background: #000000de;
      -webkit-transition:transform .5s ease-out;
      -o-transition:transform .5s ease-out;
      transition:transform .5s ease-out;
    }
    .btns.hide{
      -webkit-transform:translateY(-100px);
      -ms-transform:translateY(-100px);
      -o-transform:translateY(-100px);
      transform:translateY(-100px);
    }
    .btns>a{
      padding: 5px;
      background: #f8981e;
      color: black;
      border-radius: 5px;
      font-weight: bold;
      text-decoration: none;
      margin: 1px;
      font-family: Arial,Helvetica,sans-serif;
    }
    .btns>a:hover{
      background: #ffa31a;
    }
    .btns>a>span{
      background: #2f2f2f;
      color: white;
      padding: 5px;
      margin: 0 5px 0 -5px;
      border-radius: 5px 0 0 5px;
    }
    .btns>a:hover>span{
      background: #3f3f3f;
    }
    .btns>label{
      background: #f8981e;
      color: black;
      border-radius: 5px;
      font-weight: bold;
      text-decoration: none;
      padding: 3px;
    }
    .btns>input[type=checkbox]{
      width:20px;
      height:20px;
      vertical-align: top;
    }
    .btns>input[type=number]{
      width: 48px;
      height: 25px;
      border-radius: 3px 0 0 3px;
      -moz-border-radius: 3px 0 0 3px;
      -webkit-border-radius: 3px 0 0 3px;
      -ms-border-radius: 3px 0 0 3px;
      -o-border-radius: 3px 0 0 3px;
      border: none;
      color: #cacaca;
      background-color: #363636;
      display: inline-block;
      font-size: 14px;
      outline: 0;
      padding: 2px 5px;
      vertical-align: top;
      margin: 0 5px;
    }
    .btns>span{
      right: 10px;
      font-size: x-large;
      position: absolute;
      cursor: pointer;
      filter: brightness(0.5);
    }
    .lighted>.btns>span{
      filter: none;
    }
    .btns>button:hover{
      transform: scale3d(1.1, 1.1, 1.1);
    }
    .lighted>.img-con>img.list-show{
      opacity: 1;
    }
    .btns>button{
      cursor: pointer;
      background: #0075ff;
      color: white;
      border-radius: 5px;
      font-weight: bold;
      text-decoration: none;
      padding: 8px 5px 5px 5px;
      margin: 0px 10px 0 10px;
      border: 0;
      transition: transform .3s ease 0s;
      transform: scale3d(1, 1, 1);
    }`);

    btns.className="btns";
    document.body.appendChild(btns);
    homepage.innerHTML=createHTML("<span>Home</span>page");
    homepage.href="https://sleazyfork.org/en/users/8227-hoothin";
    homepage.target="_blank";
    numInput.type="number";
    numInput.title=numInput.placeholder="Num of sexy pictures";
    r18Check.type="checkbox";
    r18Check.id="r18Check";
    r18CheckLabel.innerText="R18 ";
    r18CheckLabel.htmlFor="r18Check";
    sfwCheck.type="checkbox";
    sfwCheck.id="sfwCheck";
    sfwCheckLabel.innerText="SFW ";
    sfwCheckLabel.htmlFor="sfwCheck";
    submit.innerText="Refresh";
    submit.onclick=submitParam;
    document.onkeyup = function(e) {
        var event = e || window.event;
        var key = event.which || event.keyCode || event.charCode;
        if (key == 13) {
            submitParam();
        }
    };
    lightBtn.innerText="💡";
    lightBtn.onclick=e=>{
        document.body.classList.toggle("lighted");
    }

    imgCon.className="img-con";
    document.body.appendChild(imgCon);
    imgCon.style.paddingTop=parseInt(window.getComputedStyle(btns).height.replace("px",""))+20+"px";
    document.body.addEventListener("touchstart",e=>{
        var lastHover=document.querySelector(".list-show.hover");
        if(lastHover)lastHover.classList.remove("hover");
        if(e.target.className=="list-show"){
            e.target.classList.add("hover");
        }
    });

    var newPos,lastPos=0;
    window.addEventListener('scroll', function(e) {
        newPos=window.scrollY;
        if (newPos > lastPos) {
            btns.classList.add("hide");
        } else {
            btns.classList.remove("hide");
        }
        lastPos=newPos;
    });
})();