thisVID.com Native Player (HTML5) and download

Replace video player with HTML5 native player (also enables download of videos)

Version vom 08.02.2025. Aktuellste Version

Du musst eine Erweiterung wie Tampermonkey, Greasemonkey oder Violentmonkey installieren, um dieses Skript zu installieren.

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 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.

Sie müssten eine Skript Manager Erweiterung installieren damit sie dieses Skript installieren können

(Ich habe schon ein Skript Manager, Lass mich es installieren!)

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         thisVID.com Native Player (HTML5) and download
// @namespace    _pc
// @version      2
// @license      MIT
// @description  Replace video player with HTML5 native player (also enables download of videos)
// @author       verydelight
// @match        *://thisvid.com/videos/*
// @grant        none
// ==/UserScript==

(function() {
	'use strict';
	function insertVideo() {
		const videoElement = document.querySelector('video.fp-engine');
		if (!videoElement) return;
		const videoUrl = videoElement.src;
		const fpPlayer = document.querySelector('.fp-player');
		const ktPlayer = document.getElementById('kt_player');
		const imgElement = document.querySelector('.video-holder img');
		[fpPlayer, ktPlayer, imgElement].forEach(el => el?.remove());
		const newVideoElement = document.createElement('video');
		newVideoElement.src = videoUrl;
		newVideoElement.controls = true;
		newVideoElement.setAttribute("style", "width:100%;");
		const videoHolder = document.querySelector('.video-holder');
		if (videoHolder) {
			videoHolder.appendChild(newVideoElement);
			newVideoElement.play();
		}
		observer.disconnect();
	}
	const observer = new MutationObserver(mutations => {
		mutations.forEach(mutation => {
			if (mutation.addedNodes.length) {
				insertVideo();
			}
		});
	});
	const targetNode = document.body;
	const config = { childList: true, subtree: true };
	observer.observe(targetNode, config);
})();