Greasy Fork

AnimeFLV-auto-skip-Mega-addon

Set video on fullscreen and send data to AnimeFLV addon

安装此脚本?
作者推荐脚本

您可能也喜欢AnimeFlV auto skip

安装此脚本
// ==UserScript==
// @name         AnimeFLV-auto-skip-Mega-addon
// @namespace    https://grayapps.es/
// @version      0.0.1
// @description  Set video on fullscreen and send data to AnimeFLV addon
// @author       Javiergg
// @match        https://mega.nz/embed/*
// @icon         
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    console.log("Mega Video Addon running");
    let interval = undefined;

    function logVideoTimes() {
        const video = document.querySelector('video');
        if (video) {
            // Ensure the video is loaded
            video.addEventListener('loadedmetadata', function() {
                if (interval) {
                    clearInterval(interval);
                }
                interval = setInterval(() => {
                    const data = {
                        currentTime: video.currentTime,
                        duration: video.duration
                    };
                    window.parent.postMessage({ type: 'VIDEO_DATA', data: data }, '*');
                }, 1000);

                // Autoplay the video
                video.play().catch(error => {
                    console.log('Autoplay failed:', error);
                });

                // Enter fullscreen mode
                if (video.requestFullscreen) {
                    video.requestFullscreen().catch(error => {
                        console.log('Fullscreen request failed:', error);
                    });
                } else if (video.mozRequestFullScreen) { // Firefox
                    video.mozRequestFullScreen().catch(error => {
                        console.log('Fullscreen request failed:', error);
                    });
                } else if (video.webkitRequestFullscreen) { // Chrome, Safari and Opera
                    video.webkitRequestFullscreen().catch(error => {
                        console.log('Fullscreen request failed:', error);
                    });
                } else if (video.msRequestFullscreen) { // IE/Edge
                    video.msRequestFullscreen().catch(error => {
                        console.log('Fullscreen request failed:', error);
                    });
                }
            });
        } else {
            console.log("No video element found.");
        }
    }

    // Attempt to log times when the DOM is loaded
    window.addEventListener('load', function() {
        logVideoTimes();
    });

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