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