Loop HTML5 Videos Toggle

Enables loop functionality for HTML5 videos with context menu toggle

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

You will need to install an extension such as Tampermonkey to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

// ==UserScript==
// @name         Loop HTML5 Videos Toggle
// @namespace   StephenP
// @version      1.0
// @description  Enables loop functionality for HTML5 videos with context menu toggle
// @author      StephenP
// @match        *://*/*
// @grant        GM_registerMenuCommand
// @grant        GM_unregisterMenuCommand
// ==/UserScript==

(function() {
    'use strict';
    let isLoopingEnabled = false;
    GM_registerMenuCommand('▶️ Enable Loop',setLooping);
    // Variables to track the state of looping

    const videoElements = document.getElementsByTagName('VIDEO');

    function toggleVideoLoop(video) {
        if (!video.loop) {
            video.loop = true;
            video.removeEventListener('ended',vPause);
            video.addEventListener('ended',vPlay);
        } else {
            video.loop = false;
            video.removeEventListener('ended',vPlay);
            video.addEventListener('ended',vPause);
        }
    }

    // Toggle loop when clicking on videos
    function setLooping(){
      if(!isLoopingEnabled){
        GM_unregisterMenuCommand('▶️ Enable Loop')
        GM_registerMenuCommand('⏹️ Disable Loop',setLooping)
        isLoopingEnabled=true;
      }
      else{
        GM_unregisterMenuCommand('⏹️ Disable Loop')
        GM_registerMenuCommand('▶️ Enable Loop',setLooping)
        isLoopingEnabled=false;
      }
      for(let video of videoElements){
        toggleVideoLoop(video);
      }
    }

    function vPause(e){
      e.target.pause();
    }
    function vPlay(e){
      e.target.play();
    }
})();