RandomSexyPicParser

Random Sexy Pictures Parser

Ajankohdalta 13.6.2024. Katso uusin versio.

  1. // ==UserScript==
  2. // @name RandomSexyPicParser
  3. // @name:zh-TW 軟瑟盤
  4. // @name:ja RandomSexyPicParser
  5. // @namespace hoothin
  6. // @version 1.3.19
  7. // @description Random Sexy Pictures Parser
  8. // @description:zh-TW 隨機色圖
  9. // @description:ja Random Sexy Pictures Parser
  10. // @author hoothin
  11. // @match https://api.lolicon.app/setu/v2*
  12. // @match https://api.nyan.xyz/httpapi/sexphoto*
  13. // @match https://huanmengii.xyz/ZY/aCOS/cos*
  14. // @match https://api.uomg.com/api/rand.img3*
  15. // @match https://api.vvhan.com/api/tao*
  16. // @match https://www.hlapi.cn/api/mjx*
  17. // @match https://3650000.xyz/api/?*
  18. // @match *://*/*
  19. // @icon 
  20. // @grant GM_addStyle
  21. // @grant GM_setValue
  22. // @grant GM_getValue
  23. // @grant GM_xmlhttpRequest
  24. // @grant GM_registerMenuCommand
  25. // @run-at document-idle
  26. // @license MIT
  27. // ==/UserScript==
  28. if (window.top != window.self) {
  29. return;
  30. }
  31.  
  32. (function() {
  33. 'use strict';
  34. var setuConfig={
  35. "api.lolicon.app":{
  36. include: /setu\/v2/i,
  37. name:"Lolicon ACG SexyPic",
  38. url:"https://api.lolicon.app/setu/v2?r18=1&num=10",
  39. luckyUrl:["https://api.lolicon.app/setu/v2?r18=0&num=5",
  40. "https://api.lolicon.app/setu/v2?r18=1&num=5",
  41. "https://api.lolicon.app/setu/v2?r18=2&num=5"],
  42. run:()=>{
  43. var searchNum=getSearchParam("num");
  44. var leftNum=searchNum;
  45. if(jsonData != "Forbidden"){
  46. let datas=jsonData.data;
  47. datas.forEach(function(data){
  48. leftNum--;
  49. let img=createImg(data.urls?data.urls.original:data.url);
  50. img.title=data.title+" - "+data.author;
  51. });
  52. }else{
  53. location.href=curConfig.url;
  54. }
  55. processByTime(leftNum,loadNum=>{
  56. GM_xmlhttpRequest({
  57. method: 'GET',
  58. url: curConfig.url.replace("num=5","num="+loadNum),
  59. timeout:15000,
  60. onload: function(result) {
  61. let datas=JSON.parse(result.responseText).data;
  62. datas.forEach(function(data){
  63. let img=createImg(data.urls?data.urls.original:data.url);
  64. img.title=data.title+" - "+data.author;
  65. });
  66. }
  67. });
  68. },5,1000);
  69. },
  70. getSearch:(param)=>{
  71. return `v2?r18=${param.r18}&num=${param.num}`;
  72. },
  73. initSearch:()=>{
  74. var searchNum=getSearchParam("num");
  75. var searchR18=getSearchParam("r18");
  76. numInput.value=searchNum;
  77. r18Check.checked=searchR18==1||searchR18==2;
  78. sfwCheck.checked=searchR18==0||searchR18==2;
  79. }
  80. },
  81. "api.nyan.xyz":{
  82. hide: true,
  83. include: /httpapi\/sexphoto/i,
  84. name:"Nyan ACG SexyPic",
  85. url:"https://api.nyan.xyz/httpapi/sexphoto/?r18=true&num=10",
  86. luckyUrl:["https://api.nyan.xyz/httpapi/sexphoto/?r18=true&num=5",
  87. "https://api.nyan.xyz/httpapi/sexphoto/?r18=false&num=5"],
  88. run:()=>{
  89. var searchNum=getSearchParam("num");
  90. var leftNum=searchNum;
  91. var urls=jsonData.data.url;
  92. if(!urls instanceof Array){
  93. urls=[urls];
  94. }
  95. urls.forEach(function(data){
  96. leftNum--;
  97. createImg(data);
  98. });
  99. processByTime(leftNum,loadNum=>{
  100. GM_xmlhttpRequest({
  101. method: 'GET',
  102. url: curConfig.url.replace("num=5","num="+loadNum),
  103. timeout:15000,
  104. onload: function(result) {
  105. urls=JSON.parse(result.responseText).data.url;
  106. urls.forEach(function(data){
  107. createImg(data);
  108. });
  109. }
  110. });
  111. },5,1000);
  112. },
  113. getSearch:(param)=>{
  114. return `?r18=${param.r18==1?"true":"false"}&num=${param.num}`;
  115. },
  116. initSearch:()=>{
  117. var searchNum=getSearchParam("num");
  118. var searchR18=getSearchParam("r18");
  119. numInput.value=searchNum;
  120. r18Check.checked=searchR18=="true";
  121. sfwCheck.checked=searchR18=="false";
  122. }
  123. },
  124. "buyersShow":{
  125. include: /api\/(rand|tao|mjx1)/i,
  126. name:"Taobao Buyers Show",
  127. urls:["https://api.uomg.com/api/rand.img3?format=json&num=15",
  128. "https://api.vvhan.com/api/tao?type=json&num=15",
  129. "https://www.hlapi.cn/api/mjx1?type=json&num=15"],
  130. run:()=>{
  131. r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
  132. var searchNum=getSearchParam("num");
  133. processByTime(searchNum,loadNum=>{
  134. for(let i=0;i<loadNum;i++){
  135. createImg(location.href.replace(/1?\?.*/,"?")+"r="+Math.random());
  136. }
  137. },5,1000);
  138. },
  139. getSearch:(param)=>{
  140. return location.href.replace(/\d+$/,"")+param.num;
  141. },
  142. initSearch:()=>{
  143. var searchNum=getSearchParam("num");
  144. numInput.value=searchNum;
  145. }
  146. },
  147. "huanmengii.xyz":{
  148. hide: true,
  149. include: /ZY\/aCOS\/cos/i,
  150. name:"Cosplay Show",
  151. url:"https://huanmengii.xyz/ZY/aCOS/cos/?type=json&num=15",
  152. run:()=>{
  153. r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
  154. var searchNum=getSearchParam("num");
  155. processByTime(searchNum,loadNum=>{
  156. for(let i=0;i<loadNum;i++){
  157. GM_xmlhttpRequest({
  158. method: 'GET',
  159. url: curConfig.url+"&"+Math.random(),
  160. timeout:15000,
  161. onload: function(result) {
  162. var curUrl=JSON.parse(result.responseText).pic;
  163. createImg(curUrl);
  164. }
  165. });
  166. }
  167. },5,1000);
  168. },
  169. getSearch:(param)=>{
  170. return "?type=json&num="+param.num;
  171. },
  172. initSearch:()=>{
  173. var searchNum=getSearchParam("num");
  174. numInput.value=searchNum;
  175. }
  176. },
  177. "3650000.xyz":{
  178. include: /\/api\/\?type=json/i,
  179. name:"3650000",
  180. url:"https://3650000.xyz/api/?type=json&mode=7&num=15",
  181. luckyUrl:["https://3650000.xyz/api/?type=json&num=15",
  182. "https://3650000.xyz/api/?type=json&mode=1&num=15",
  183. "https://3650000.xyz/api/?type=json&mode=2&num=15",
  184. "https://3650000.xyz/api/?type=json&mode=3&num=15",
  185. "https://3650000.xyz/api/?type=json&mode=66&num=15",
  186. "https://3650000.xyz/api/?type=json&mode=5&num=15",
  187. "https://3650000.xyz/api/?type=json&mode=7&num=15",
  188. "https://3650000.xyz/api/?type=json&mode=8&num=15",
  189. "https://3650000.xyz/api/?type=json&mode=9&num=15"],
  190. run:()=>{
  191. r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
  192. var searchNum=getSearchParam("num");
  193. var searchMode=getSearchParam("mode");
  194. processByTime(searchNum,loadNum=>{
  195. for(let i=0;i<loadNum;i++){
  196. GM_xmlhttpRequest({
  197. method: 'GET',
  198. url: `${curConfig.url}&mode=${searchMode}&${Math.random()}`,
  199. timeout:15000,
  200. onload: function(result) {
  201. var curUrl=JSON.parse(result.responseText).url;
  202. createImg(curUrl);
  203. }
  204. });
  205. }
  206. },5,1000);
  207. },
  208. getSearch:(param)=>{
  209. return location.pathname+`?type=json&mode=${param.mode}&num=${param.num}`;
  210. },
  211. initSearch:()=>{
  212. var searchNum=getSearchParam("num");
  213. var searchMode=getSearchParam("mode");
  214. var modeObj=[
  215. ["Public",""],
  216. ["Weibo","1"],
  217. ["Instagram","2"],
  218. ["Cosplay","3"],
  219. ["Nsfw","66"],
  220. ["Mtcos","5"],
  221. ["Legs","7"],
  222. ["MoreCoser","8"],
  223. ["Tuwan","9"]
  224. ];
  225. modeObj.forEach(item=>{
  226. var option=document.createElement("option");
  227. option.value=item[1];
  228. option.innerText=item[0];
  229. if(item[1]==searchMode){
  230. option.selected=true;
  231. }
  232. modeSelect.appendChild(option);
  233. });
  234. modeSelect.style.display="inline";
  235. numInput.value=searchNum;
  236. }
  237. },
  238. "api.uomg.com":"buyersShow",
  239. "api.vvhan.com":"buyersShow",
  240. "www.hlapi.cn":"buyersShow",
  241. "api.ghser.com":"buyersShow"
  242. };
  243. var customRule=GM_getValue("RSPrules") || {};
  244. var customRuleArr=[];
  245. for(var j in customRule){
  246. let href=customRule[j];
  247. customRuleArr.push(href);
  248. }
  249. GM_registerMenuCommand("I am feeling lucky", ()=>{
  250. var luckyUrls=[],targetUrl;
  251. for(var i in setuConfig){
  252. let sc=setuConfig[i];
  253. if(sc.hide){
  254. continue;
  255. }else if(sc.luckyUrl){
  256. luckyUrls=luckyUrls.concat(sc.luckyUrl);
  257. }else if(sc.urls){
  258. luckyUrls=luckyUrls.concat(sc.urls);
  259. }else if(sc.url){
  260. luckyUrls.push(sc.url);
  261. }
  262. }
  263. luckyUrls=luckyUrls.concat(customRuleArr);
  264. var randomIndex=Math.floor(Math.random()*luckyUrls.length);
  265. targetUrl=luckyUrls[randomIndex];
  266. location.href=targetUrl;
  267. });
  268. const _unsafeWindow = (typeof unsafeWindow == 'undefined') ? window : unsafeWindow;
  269. const escapeHTMLPolicy = (_unsafeWindow.trustedTypes && _unsafeWindow.trustedTypes.createPolicy) ? _unsafeWindow.trustedTypes.createPolicy('rspp_default', {
  270. createHTML: (string, sink) => string
  271. }) : null;
  272.  
  273. function createHTML(html) {
  274. return escapeHTMLPolicy ? escapeHTMLPolicy.createHTML(html) : html;
  275. }
  276. if (location.href.indexOf("randomsexypicparser") != -1) {
  277. GM_addStyle(".discussion-rating{display:none}");
  278. }
  279. var curConfig=setuConfig[document.domain],jsonData,hasFloatImg=false,grabed=false,oClient;
  280. if(curConfig){
  281. if(!curConfig.run){
  282. curConfig=setuConfig[curConfig];
  283. }
  284. if(curConfig.include && !curConfig.include.test(location.href)){
  285. curConfig=false;
  286. }
  287. }
  288. if(!curConfig){
  289. let currentParsing=customRule[document.domain+location.pathname];
  290. if(!currentParsing){
  291. GM_registerMenuCommand("Parse current api", customSet);
  292. return;
  293. }else{
  294. GM_registerMenuCommand("Stop parse api", () => {
  295. delete customRule[document.domain+location.pathname];
  296. GM_setValue("RSPrules", customRule);
  297. location.reload();
  298. });
  299. curConfig={run:()=>{
  300. var searchNum=getSearchParam("num");
  301. var leftNum=searchNum;
  302. r18Check.style.display=sfwCheck.style.display=r18CheckLabel.style.display=sfwCheckLabel.style.display="none";
  303. let parsePics=(data)=>{
  304. let picUrls=[],urlReg=/(https?|ftp|file):\/\/[\-A-Za-z0-9\+&@#/%?=~_\|!:,\.;]+[\-A-Za-z0-9\+&@#/%=~_\|]/g;
  305. if(typeof data == "string"){
  306. picUrls=data.match(urlReg);
  307. }else{
  308. let checkJson=obj=>{
  309. for(let i in obj){
  310. if(typeof obj[i] == "string"){
  311. let pics=obj[i].match(urlReg);
  312. if(pics)picUrls=picUrls.concat(pics);
  313. }else checkJson(obj[i]);
  314. }
  315. };
  316. checkJson(data);
  317. }
  318. if(picUrls){
  319. picUrls=picUrls.filter((item, index) => picUrls.indexOf(item) === index);
  320. picUrls.forEach(url=>{
  321. leftNum--;
  322. createImg(unescape(url));
  323. });
  324. }
  325. }
  326. parsePics(jsonData);
  327. processByTime(leftNum||1, loadNum=>{
  328. let href=location.href.replace(/num=\d+(&time=\d+)?/,"num="+loadNum+"&time="+Date.now()),postParams=href.match(/#p{(.*)}/);
  329. if(postParams){
  330. postParams=postParams[1];
  331. href=href.replace(/#p{.*/,"");
  332. }
  333. GM_xmlhttpRequest({
  334. method: postParams?'POST':'GET',
  335. data: postParams,
  336. headers: {
  337. 'Referer': location.href,
  338. "Content-Type": (postParams ? "application/x-www-form-urlencoded" : "text/html") + ";charset=" + (document.characterSet || document.charset || document.inputEncoding),
  339. },
  340. url: href,
  341. timeout:15000,
  342. onload: function(result) {
  343. var parseData;
  344. try{
  345. parseData=JSON.parse(result.responseText);
  346. console.log(parseData);
  347. }catch(e){
  348. parseData=result.responseText;
  349. }
  350. parsePics(parseData);
  351. }
  352. });
  353. }, (leftNum < searchNum - 1 ? 5 : 1), 1000);
  354. },
  355. getSearch:(param)=>{
  356. var href=location.href;
  357. if(/\bnum=/.test(href)){
  358. href=href.replace(/\bnum=\d+(&time=\d+)?/,"num="+param.num+"&time="+Date.now());
  359. }else{
  360. if(href.indexOf("?")==-1){
  361. if(href.indexOf("#")==-1){
  362. href+="?num="+param.num+"&time="+Date.now();
  363. }else{
  364. href=href.replace("#","?num="+param.num+"&time="+Date.now()+"#");
  365. }
  366. }else{
  367. href+="&num="+param.num+"&time="+Date.now();
  368. }
  369. }
  370. return href;
  371. },
  372. initSearch:()=>{
  373. var searchNum=getSearchParam("num");
  374. numInput.value=searchNum;
  375. }};
  376. }
  377. }
  378. document.title=curConfig.name?curConfig.name:"Random Sexy Pictures";
  379. try{
  380. var firstText = "";
  381. for (var i = 0; i < document.body.childNodes.length; i++) {
  382. var curNode = document.body.childNodes[i];
  383. if (curNode.nodeType == 1 || curNode.nodeName == "PRE") {
  384. firstText = curNode.nodeValue || curNode.innerText;
  385. if (firstText) break;
  386. }
  387. }
  388. if(firstText)jsonData=JSON.parse(firstText);
  389. }catch(e){
  390. console.log(e);
  391. jsonData=firstText;
  392. }
  393. document.body.innerHTML=createHTML("");
  394. var imgCon=document.createElement("div");
  395. var btns=document.createElement("div");
  396. var numInput=document.createElement("input");
  397. var r18Check=document.createElement("input");
  398. var r18CheckLabel=document.createElement("label");
  399. var sfwCheck=document.createElement("input");
  400. var sfwCheckLabel=document.createElement("label");
  401. var modeSelect=document.createElement("select");
  402. var submit=document.createElement("button");
  403. var referrerMeta=document.createElement("meta");
  404. var viewportMeta=document.createElement("meta");
  405. var overMask=document.createElement("div");
  406. var homepage=document.createElement("a");
  407. var lightBtn=document.createElement("span");
  408. for(var name in setuConfig){
  409. var config=setuConfig[name];
  410. if(config.hide || !config.name)continue;
  411. var siteA=document.createElement("a");
  412. var url=config.url;
  413. if(config.urls){
  414. var randomIndex=Math.floor(Math.random()*config.urls.length);
  415. url=config.urls[randomIndex];
  416. config.url=url;
  417. }
  418. siteA.href=url;
  419. siteA.innerText=config.name;
  420. btns.appendChild(siteA);
  421. }
  422. if(customRuleArr.length){
  423. var otherSiteA=document.createElement("a");
  424. otherSiteA.href=customRuleArr[Math.floor(Math.random()*customRuleArr.length)];
  425. otherSiteA.innerText="Other";
  426. btns.appendChild(otherSiteA);
  427. }
  428. btns.appendChild(numInput);
  429. btns.appendChild(r18Check);
  430. btns.appendChild(r18CheckLabel);
  431. btns.appendChild(sfwCheck);
  432. btns.appendChild(sfwCheckLabel);
  433. btns.appendChild(modeSelect);
  434. btns.appendChild(submit);
  435. btns.appendChild(homepage);
  436. btns.appendChild(lightBtn);
  437. overMask.className="over-mask";
  438. imgCon.appendChild(overMask);
  439. referrerMeta.name="referrer";
  440. referrerMeta.content="never";
  441. document.head.appendChild(referrerMeta);
  442. viewportMeta.name="viewport";
  443. viewportMeta.content="width=device-width, initial-scale=1";
  444. document.head.appendChild(viewportMeta);
  445.  
  446. curConfig.run();
  447. if(curConfig.initSearch)curConfig.initSearch();
  448.  
  449. function sleep(fn,param,time) {
  450. return new Promise((resolve) => {
  451. setTimeout(() => resolve(fn(param)), time)
  452. })
  453. }
  454. async function processByTime(num,fn,limit,time) {
  455. while(num>0){
  456. var loadNum=limit;
  457. if(num<limit)loadNum=num;
  458. num-=loadNum;
  459. await sleep(fn,loadNum,time);
  460. }
  461. }
  462.  
  463. overMask.onclick=e=>{
  464. if(hasFloatImg){
  465. restoreImg(hasFloatImg);
  466. }
  467. };
  468.  
  469. function mousedownHandler(e){
  470. let img=e.target;
  471. img.addEventListener("mouseup",mouseupHandler);
  472. img.addEventListener("mousemove",mousemoveHandler);
  473. img.style.cursor="grabbing";
  474. oClient={
  475. x:window.scrollX+e.clientX,
  476. y:window.scrollY+e.clientY,
  477. };
  478. e.stopPropagation();
  479. e.preventDefault();
  480. e.returnValue=false;
  481. }
  482. function mousemoveHandler(e){
  483. let img=e.target;
  484. grabed=true;
  485. window.scrollTo(oClient.x-e.clientX, oClient.y-e.clientY);
  486. }
  487. function mouseupHandler(e){
  488. let img=e.target;
  489. img.removeEventListener("mouseup",mouseupHandler);
  490. img.removeEventListener("mousemove",mousemoveHandler);
  491. img.style.cursor="grab";
  492. }
  493. function grabHandler(img,add){
  494. if(add){
  495. img.addEventListener("mousedown",mousedownHandler);
  496. }else{
  497. img.removeEventListener("mousedown",mousedownHandler);
  498. }
  499. }
  500.  
  501. function restoreImg(img){
  502. hasFloatImg=false;
  503. img.style.zIndex=0;
  504. img.style.bottom="";
  505. img.style.width="100%";
  506. img.style.position="";
  507. img.style.margin="";
  508. document.body.style.overflow="";
  509. imgCon.style.maxHeight="";
  510. imgCon.style.maxWidth="";
  511. overMask.style.display="none";
  512. overMask.style.opacity=0;
  513. img.className="list-show";
  514. grabHandler(img,false);
  515. img.style.cursor="";
  516. img.scrollIntoView({ block: "center", inline: "center" });
  517. }
  518.  
  519. function createImg(url){
  520. let img=document.createElement("img");
  521. img.onerror=e=>{
  522. img.style.display="none";
  523. };
  524. img.src=url;
  525. img.className="list-show";
  526. img.style.width="100%";
  527. img.onclick=()=>{
  528. if(grabed){
  529. grabed=false;
  530. return;
  531. }
  532. window.scrollTo(0,0);
  533. var de=document.documentElement;
  534. var body=document.body;
  535. var backCompat=document.compatMode=='BackCompat';
  536. var windowSize={
  537. h: backCompat ? body.clientHeight : de.clientHeight,
  538. w: backCompat ? body.clientWidth : de.clientWidth,
  539. };
  540. if(img.style.zIndex==2){
  541. restoreImg(img);
  542. }else if(img.style.zIndex==1){
  543. img.style.bottom="";
  544. img.style.width="";
  545. img.style.maxWidth="";
  546. img.style.maxHeight="";
  547. img.style.zIndex=2;
  548. img.style.cursor="grab";
  549. grabHandler(img,true);
  550. document.body.style.overflow="";
  551. imgCon.style.maxWidth="100vw";
  552. imgCon.style.maxHeight="100vh";
  553. }else{
  554. if(hasFloatImg)return;
  555. hasFloatImg=img;
  556. document.body.style.overflow="hidden";
  557. img.style.bottom=0;
  558. if(img.naturalWidth>windowSize.w || img.naturalHeight>windowSize.h){
  559. img.style.zIndex=1;
  560. img.style.maxWidth="99%";
  561. img.style.maxHeight="99%";
  562. }else{
  563. img.style.zIndex=2;
  564. img.style.maxWidth="";
  565. img.style.maxHeight="";
  566. }
  567. img.style.width="";
  568. img.style.position="absolute";
  569. img.style.margin="auto";
  570. overMask.style.display="block";
  571. img.className="";
  572. setTimeout(()=>{
  573. overMask.style.opacity=1;
  574. }, 0);
  575. }
  576. };
  577. imgCon.appendChild(img);
  578. return img;
  579. }
  580.  
  581. function getSearchParam(name){
  582. let reg = new RegExp("(&|^)" + name + "=([^&]*)(&|$)", "i");
  583. let r = window.location.search.substr(1).match(reg);
  584. if (r != null) {
  585. return decodeURIComponent(r[2]);
  586. };
  587. return "";
  588. }
  589.  
  590. function submitParam(){
  591. var num=numInput.value,mode;
  592. if(modeSelect.options.length>0){
  593. mode=modeSelect.options[modeSelect.selectedIndex].value;
  594. }
  595. var r18=2;
  596. if(sfwCheck.checked && !r18Check.checked){
  597. r18=0;
  598. }else if(!sfwCheck.checked && r18Check.checked){
  599. r18=1;
  600. }
  601. if(numInput.value != ""){
  602. location.href=curConfig.getSearch({"r18":r18, "num":num, "mode":mode});
  603. }else{
  604. location.reload();
  605. }
  606. }
  607.  
  608. function customSet(){
  609. if(window.confirm("Parse current api?")){
  610. customRule[document.domain+location.pathname]=location.href;
  611. GM_setValue("RSPrules", customRule);
  612. location.reload();
  613. }
  614. }
  615.  
  616. GM_addStyle(`
  617. @media screen and (min-width: 1024px) {
  618. .img-con{
  619. column-count: 5;
  620. -moz-column-count: 5;
  621. -webkit-column-count: 5;
  622. }
  623. .img-con>img{
  624. min-height: 250px;
  625. }
  626. }
  627. @media screen and (max-width: 1024px) {
  628. .img-con{
  629. column-count: 2;
  630. -moz-column-count: 2;
  631. -webkit-column-count: 2;
  632. }
  633. .img-con>img{
  634. min-height: 50px;
  635. }
  636. }
  637. body{
  638. background: black;
  639. scrollbar-width: none;
  640. }
  641. body::-webkit-scrollbar {
  642. width: 0 !important;
  643. height: 0 !important;
  644. }
  645. .btns>select{
  646. display: none;
  647. height: 29px;
  648. border-radius: 3px 0 0 3px;
  649. -moz-border-radius: 3px 0 0 3px;
  650. -webkit-border-radius: 3px 0 0 3px;
  651. -ms-border-radius: 3px 0 0 3px;
  652. -o-border-radius: 3px 0 0 3px;
  653. border: none;
  654. color: #cacaca;
  655. background-color: #363636;
  656. font-size: 14px;
  657. outline: 0;
  658. padding: 2px 5px;
  659. vertical-align: top;
  660. }
  661. .over-mask{
  662. display: none;
  663. opacity: 0;
  664. width: 100%;
  665. height: 100%;
  666. background-color: #000000e6;
  667. position: fixed;
  668. z-index: 1;
  669. top: 0;
  670. left: 0;
  671. transition: opacity .3s ease-in-out;
  672. -moz-transition: opacity .3s ease-in-out;
  673. -o-transition: opacity .3s ease-in-out;
  674. -webkit-transition: opacity .3s ease-in-out;
  675. }
  676. .list-show:hover,.list-show.hover{
  677. opacity: 1;
  678. transform: scale(1.05);
  679. }
  680. .list-show{
  681. opacity: 0.6;
  682. transition: opacity .3s ease-in-out, transform .3s;
  683. -moz-transition: opacity .3s ease-in-out, transform .3s;
  684. -webkit-transition: opacity .3s ease-in-out, transform .3s;
  685. }
  686. .img-con{
  687. overflow-x: hidden;
  688. overflow: auto;
  689. width: 100%;
  690. min-height: calc(100vh - 70px);
  691. display: block;
  692. scrollbar-width: none;
  693. }
  694. .img-con::-webkit-scrollbar {
  695. width: 0 !important;
  696. height: 0 !important;
  697. }
  698. .img-con>img{
  699. -webkit-column-break-inside: avoid;
  700. break-inside: avoid;
  701. float: left;
  702. margin-bottom: 15px;
  703. margin-right: 15px;
  704. overflow: hidden;
  705. position: relative;
  706. top: 0;
  707. left: 0;
  708. right: 0;
  709. background: url() no-repeat center center;
  710. }
  711. .btns{
  712. padding: 10px 0;
  713. text-align: center;
  714. line-height: 30px;
  715. position: fixed;
  716. z-index: 1;
  717. width: 100%;
  718. top: 0;
  719. left: 0;
  720. background: #000000de;
  721. -webkit-transition:transform .5s ease-out;
  722. -o-transition:transform .5s ease-out;
  723. transition:transform .5s ease-out;
  724. }
  725. .btns.hide{
  726. -webkit-transform:translateY(-100px);
  727. -ms-transform:translateY(-100px);
  728. -o-transform:translateY(-100px);
  729. transform:translateY(-100px);
  730. }
  731. .btns>a{
  732. padding: 5px;
  733. background: #f8981e;
  734. color: black;
  735. border-radius: 5px;
  736. font-weight: bold;
  737. text-decoration: none;
  738. margin: 1px;
  739. font-family: Arial,Helvetica,sans-serif;
  740. }
  741. .btns>a:hover{
  742. background: #ffa31a;
  743. }
  744. .btns>a>span{
  745. background: #2f2f2f;
  746. color: white;
  747. padding: 5px;
  748. margin: 0 5px 0 -5px;
  749. border-radius: 5px 0 0 5px;
  750. }
  751. .btns>a:hover>span{
  752. background: #3f3f3f;
  753. }
  754. .btns>label{
  755. background: #f8981e;
  756. color: black;
  757. border-radius: 5px;
  758. font-weight: bold;
  759. text-decoration: none;
  760. padding: 3px;
  761. }
  762. .btns>input[type=checkbox]{
  763. width:20px;
  764. height:20px;
  765. vertical-align: top;
  766. }
  767. .btns>input[type=number]{
  768. width: 48px;
  769. height: 25px;
  770. border-radius: 3px 0 0 3px;
  771. -moz-border-radius: 3px 0 0 3px;
  772. -webkit-border-radius: 3px 0 0 3px;
  773. -ms-border-radius: 3px 0 0 3px;
  774. -o-border-radius: 3px 0 0 3px;
  775. border: none;
  776. color: #cacaca;
  777. background-color: #363636;
  778. display: inline-block;
  779. font-size: 14px;
  780. outline: 0;
  781. padding: 2px 5px;
  782. vertical-align: top;
  783. margin: 0 5px;
  784. }
  785. .btns>span{
  786. right: 10px;
  787. font-size: x-large;
  788. position: absolute;
  789. cursor: pointer;
  790. filter: brightness(0.5);
  791. }
  792. .lighted>.btns>span{
  793. filter: none;
  794. }
  795. .btns>button:hover{
  796. transform: scale3d(1.1, 1.1, 1.1);
  797. }
  798. .lighted>.img-con>img.list-show{
  799. opacity: 1;
  800. }
  801. .btns>button{
  802. cursor: pointer;
  803. background: #0075ff;
  804. color: white;
  805. border-radius: 5px;
  806. font-weight: bold;
  807. text-decoration: none;
  808. padding: 8px 5px 5px 5px;
  809. margin: 0px 10px 0 10px;
  810. border: 0;
  811. transition: transform .3s ease 0s;
  812. transform: scale3d(1, 1, 1);
  813. }`);
  814.  
  815. btns.className="btns";
  816. document.body.appendChild(btns);
  817. homepage.innerHTML=createHTML("<span>Home</span>page");
  818. homepage.href="https://sleazyfork.org/en/users/8227-hoothin";
  819. homepage.target="_blank";
  820. numInput.type="number";
  821. numInput.title=numInput.placeholder="Num of sexy pictures";
  822. r18Check.type="checkbox";
  823. r18Check.id="r18Check";
  824. r18CheckLabel.innerText="R18 ";
  825. r18CheckLabel.htmlFor="r18Check";
  826. sfwCheck.type="checkbox";
  827. sfwCheck.id="sfwCheck";
  828. sfwCheckLabel.innerText="SFW ";
  829. sfwCheckLabel.htmlFor="sfwCheck";
  830. submit.innerText="Refresh";
  831. submit.onclick=submitParam;
  832. document.onkeyup = function(e) {
  833. var event = e || window.event;
  834. var key = event.which || event.keyCode || event.charCode;
  835. if (key == 13) {
  836. submitParam();
  837. }
  838. };
  839. lightBtn.innerText="💡";
  840. lightBtn.onclick=e=>{
  841. document.body.classList.toggle("lighted");
  842. }
  843.  
  844. imgCon.className="img-con";
  845. document.body.appendChild(imgCon);
  846. imgCon.style.paddingTop=parseInt(window.getComputedStyle(btns).height.replace("px",""))+20+"px";
  847. document.body.addEventListener("touchstart",e=>{
  848. var lastHover=document.querySelector(".list-show.hover");
  849. if(lastHover)lastHover.classList.remove("hover");
  850. if(e.target.className=="list-show"){
  851. e.target.classList.add("hover");
  852. }
  853. });
  854.  
  855. var newPos,lastPos=0;
  856. window.addEventListener('scroll', function(e) {
  857. newPos=window.scrollY;
  858. if (newPos > lastPos) {
  859. btns.classList.add("hide");
  860. } else {
  861. btns.classList.remove("hide");
  862. }
  863. lastPos=newPos;
  864. });
  865. })();