HTML5 Steam Trailers

Replaces Steam's own video controls with dark HTML5 controls.

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!)

Advertisement:

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!)

Advertisement:

// ==UserScript==
// @name         HTML5 Steam Trailers
// @namespace    http://pyroglyph.co.uk/
// @version      1.1
// @description  Replaces Steam's own video controls with dark HTML5 controls.
// @author       Pyroglyph
// @match        http://store.steampowered.com/*
// @grant        none
// ==/UserScript==

// Run on page load
(function() {
    'use strict';
    convertVideoToHTML5();
})();
// Also run on click because not all videos are visible on page load
onclick = function() { convertVideoToHTML5(); };

function convertVideoToHTML5() {
    // Can't find a better way to remove them ¯\_(ツ)_/¯
    var oldControls = document.querySelector('.html5_video_overlay');
    if (oldControls !== null && typeof oldControls !== 'undefined') {
        oldControls.parentNode.removeChild(oldControls);
    }

    var videos = document.getElementsByTagName('video');
    if (videos !== null && typeof videos !== 'undefined' && videos.length !== 0) {
        for (var i = 0; i < videos.length; i++) {
            videos[i].setAttributeNode(document.createAttribute('controls'));
        }
    }

    var style = document.createElement('style');
    var node = document.createTextNode('video::-webkit-media-controls { filter: grayscale(1) brightness(0.9) invert(1); }');
    style.appendChild(node);
    document.head.appendChild(style);
}