Infinite scroll [optional], Filter by Title and Duration
// ==UserScript== // @name XVideos Improved // @namespace pervertmonkey // @version 4.0.5 // @author violent-orangutan // @description Infinite scroll [optional], Filter by Title and Duration // @license MIT // @icon https://www.google.com/s2/favicons?sz=64&domain=xvideos.com // @homepage https://github.com/smartacephale/sleazy-fork // @homepageURL https://github.com/smartacephale/sleazy-fork // @source github:smartacephale/sleazy-fork // @supportURL https://github.com/smartacephale/sleazy-fork/issues // @match https://*.xvideos.com/* // @require https://cdn.jsdelivr.net/npm/[email protected]/dist/core/pervertmonkey.core.umd.js // @require data:application/javascript,var core = window.pervertmonkey.core || pervertmonkey.core; var utils = core; // @grant GM_addStyle // @grant unsafeWindow // @run-at document-idle // ==/UserScript== (function (core, utils) { 'use strict'; var _unsafeWindow = (() => typeof unsafeWindow != "undefined" ? unsafeWindow : undefined)(); const xv = _unsafeWindow.xv; new core.Rules({ paginationStrategyOptions: { paginationSelector: "#main .pagination:last-child", searchParamSelector: "p" }, containerSelector: "*:has(>div.thumb-block[id^=video_]:not(.thumb-ad))", thumbs: { selector: "div.thumb-block[id^=video_]:not(.thumb-ad)" }, thumb: { selectors: { title: "[class*=title]", uploader: "[class*=name]", duration: "[class*=duration]" }, callback: (thumb) => { setTimeout(() => { const id = parseInt(thumb.getAttribute("data-id")); xv.thumbs.prepareVideo(id); }, 200); } }, schemeOptions: ["Text Filter", "Duration Filter", "Badge", "Advanced"], animatePreview }); function animatePreview(container) { function createPreviewElement(src, mount) { const elem = utils.parseHtml(` <div class="videopv" style="display: none;"> <video autoplay="autoplay" playsinline="playsinline" muted="muted"></video> </div>`); mount.after(elem); const video = elem.querySelector("video"); video.src = src; video.addEventListener( "loadeddata", () => { mount.style.opacity = "0"; elem.style.display = "block"; elem.style.background = "#000"; }, false ); return () => { utils.exterminateVideo(video); elem.remove(); mount.style.opacity = "1"; }; } function getVideoURL(src) { return src.replace(/\w+\.\w+$/, () => "preview.mp4"); } utils.OnHover.create(container, "div.thumb-block[id^=video_]:not(.thumb-ad)", (target) => { const img = target.querySelector("img"); const videoSrc = getVideoURL(img.src); return createPreviewElement(videoSrc, img); }); } })(core, utils);