Loop HTML5 Videos Toggle

Enables loop functionality for HTML5 videos with context menu toggle

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

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

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

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

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

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==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();
    }
})();