98预告贴小助手

即点即看不跳转,周周预告看到爽

// ==UserScript==
// @name         98预告贴小助手
// @license      MIT
// @namespace    http://tampermonkey.net/
// @version      3.41
// @description  即点即看不跳转,周周预告看到爽
// @author       Lsssy
// @include      *://*.sehuatang.*/*
// @include      *://sehuatang.*/*
// @icon         
// @grant        none
// ==/UserScript==

(function () {
    'use strict';

    const fixUrl = url => {
        if (!/^https?:\/\//.test(url)) {
            url = 'https://' + url;
        }
        return url.replace(/^(https?:\/\/)?(?:[a-zA-Z0-9.-]+)?\.dmm\.co\.jp/, 'https://cc3001.dmm.co.jp');
    };

    const formatNumber = num => num.toUpperCase().replace(/^([a-zA-Z]+)0*(\d+)$/, (_, prefix, digits) => {
        return `${prefix}-${digits.padStart(3, '0')}`;
    });

    const replaceTextWithLink = node => {
        if (node.nodeType === Node.TEXT_NODE) {
            const regex = /((?:https?:\/\/)?(?:[a-zA-Z0-9.-]+)?\.dmm\.co\.jp\/.*?\/)([\w]+_\w+_\w+\.mp4)/g;
            let text = node.nodeValue, match, parent = node.parentNode, lastIndex = 0;

            while ((match = regex.exec(text)) !== null) {
                parent.insertBefore(document.createTextNode(text.slice(lastIndex, match.index)), node);
                const link = document.createElement('a');
                link.href = fixUrl(match[1] + match[2]);
                link.textContent = formatNumber(match[2].split('_')[0]);
                parent.insertBefore(link, node);
                lastIndex = regex.lastIndex;
            }

            parent.insertBefore(document.createTextNode(text.slice(lastIndex)), node);
            parent.removeChild(node);
        } else if (node.nodeType === Node.ELEMENT_NODE) {
            Array.from(node.childNodes).forEach(replaceTextWithLink);
        }
    };

    replaceTextWithLink(document.body);
})();

(function() {
    'use strict';

    document.querySelectorAll('a[href*="pv3001"], a[href*="dmm.com"], a[href*="_dm_w"]')
        .forEach(function(link) {
            link.href = link.href
                .replace('pv3001', 'cc3001')
                .replace('dmm.com', 'dmm.co.jp')
                .replace('_dm_w', 'hhb');
        });
})();

(function () {
    'use strict';
    const isMobile = /Mobi|Android|iPhone/i.test(navigator.userAgent);
    const videoModal = document.createElement('div');
    videoModal.style.cssText = 'position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:rgba(0,0,0,0.7);display:none;justify-content:center;align-items:center;z-index:1000;cursor:pointer;';
    document.body.appendChild(videoModal);

    const videoElement = document.createElement('video');
    videoElement.style.cssText = isMobile
        ? 'width:90%;height:auto;border:2px solid white;border-radius:10px;'
        : 'max-width:80%;max-height:80%;border:2px solid white;border-radius:10px;';
    videoElement.setAttribute('controls', true);
    videoElement.muted = true;
    videoModal.appendChild(videoElement);

    const videoTitle = document.createElement('div');
    videoTitle.style.cssText = isMobile
        ? 'position:absolute;top:5%;width:90%;text-align:center;font-size:18px;color:white;z-index:1001;font-family: Arial, sans-serif;opacity:0.9;'
        : 'position:absolute;top:10px;width:100%;text-align:center;font-size:22px;color:white;z-index:1001;font-family: Arial, sans-serif;opacity:0.9;';
    videoModal.appendChild(videoTitle);

    const leftButton = document.createElement('button');
    leftButton.innerText = '◁';
    leftButton.style.cssText = isMobile
        ? 'position:absolute;bottom:10%;left:10%;font-size:24px;color:white;background-color:rgba(0,0,0,0.5);border:none;padding:10px 20px;border-radius:5px;cursor:pointer;'
        : 'position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:32px;font-weight:bold;color:white;background-color:rgba(0,0,0,0.5);border:none;padding:12px 20px;border-radius:30px;cursor:pointer;';
    videoModal.appendChild(leftButton);

    const rightButton = document.createElement('button');
    rightButton.innerText = '▷';
    rightButton.style.cssText = isMobile
        ? 'position:absolute;bottom:10%;right:10%;font-size:24px;color:white;background-color:rgba(0,0,0,0.5);border:none;padding:10px 20px;border-radius:5px;cursor:pointer;'
        : 'position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:32px;font-weight:bold;color:white;background-color:rgba(0,0,0,0.5);border:none;padding:12px 20px;border-radius:30px;cursor:pointer;';
    videoModal.appendChild(rightButton);

    const videoIndexDisplay = document.createElement('div');
    videoIndexDisplay.style.cssText = isMobile
        ? 'position:fixed;top:5%;left:5%;font-size:16px;color:white;z-index:1002;font-family: Arial, sans-serif;opacity:0.9;'
        : 'position:fixed;top:10px;left:10px;font-size:18px;color:white;z-index:1002;font-family: Arial, sans-serif;opacity:0.9;';
    document.body.appendChild(videoIndexDisplay);

    let videoLinks = [];
    let currentIndex = -1;
    let isNavigatingVideos = false;

    function bindVideoLinks() {
        document.querySelectorAll('a[href*=".mp4"]').forEach(link => {
            link.addEventListener('click', function (e) {
                e.preventDefault();
                videoElement.src = link.href;
                videoElement.play();
                videoModal.style.display = 'flex';
                videoLinks = Array.from(document.querySelectorAll('a[href*=".mp4"]')).map(link => link.href);
                currentIndex = videoLinks.indexOf(link.href);
                const videoName = link.textContent.trim();
                videoTitle.textContent = videoName;
                updateVideoIndexDisplay();
            });
        });
    }

    function updateVideoIndexDisplay() {
        videoIndexDisplay.textContent = `${currentIndex + 1} / ${videoLinks.length}`;
    }

    videoModal.addEventListener('click', function (e) {
        if (e.target === videoModal) {
            videoElement.pause();
            videoModal.style.display = 'none';
        }
    });

    window.addEventListener('keydown', function (e) {
        if (e.key === 'ArrowLeft') {
            if (isNavigatingVideos) {
                loadPreviousVideo();
            } else {
                videoElement.currentTime -= 5;
            }
        } else if (e.key === 'ArrowRight') {
            if (isNavigatingVideos) {
                loadNextVideo();
            } else {
                videoElement.currentTime += 5;
            }
        }
    });

    leftButton.addEventListener('click', function () {
        isNavigatingVideos = true;
        loadPreviousVideo();
    });

    rightButton.addEventListener('click', function () {
        isNavigatingVideos = true;
        loadNextVideo();
    });

    function loadPreviousVideo() {
        if (videoLinks.length > 0) {
            currentIndex = (currentIndex === 0) ? videoLinks.length - 1 : currentIndex - 1;
            videoElement.src = videoLinks[currentIndex];
            videoElement.play();
            const videoName = document.querySelectorAll('a[href*=".mp4"]')[currentIndex].textContent.trim();
            videoTitle.textContent = videoName;
            updateVideoIndexDisplay();
        }
    }

    function loadNextVideo() {
        if (videoLinks.length > 0) {
            currentIndex = (currentIndex === videoLinks.length - 1) ? 0 : currentIndex + 1;
            videoElement.src = videoLinks[currentIndex];
            videoElement.play();
            const videoName = document.querySelectorAll('a[href*=".mp4"]')[currentIndex].textContent.trim();
            videoTitle.textContent = videoName;
            updateVideoIndexDisplay();
        }
    }

    videoElement.addEventListener('fullscreenchange', function () {
        if (document.fullscreenElement) {
            videoElement.style.border = 'none';
        } else {
            videoElement.style.border = '2px solid white';
        }
    });

    videoElement.addEventListener('click', function () {
        isNavigatingVideos = false;
    });

    window.addEventListener('load', bindVideoLinks);

    const observer = new MutationObserver(bindVideoLinks);
    observer.observe(document.body, {
        childList: true,
        subtree: true
    });
})();