WebM Inline Player

Automatically replaces links to WebM files with embedded videos

Tendrás que instalar una extensión para tu navegador como Tampermonkey, Greasemonkey o Violentmonkey si quieres utilizar este script.

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

Necesitarás instalar una extensión como Tampermonkey o Violentmonkey para instalar este script.

Necesitarás instalar una extensión como Tampermonkey o Userscripts para instalar este script.

Necesitará instalar una extensión como Tampermonkey para instalar este script.

Necesitarás instalar una extensión para administrar scripts de usuario si quieres instalar este script.

(Ya tengo un administrador de scripts de usuario, déjame instalarlo)

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

(Ya tengo un administrador de estilos de usuario, déjame instalarlo)

// ==UserScript==
// @name     			WebM Inline Player
// @version     		1.1.1
// @author     			Faberman
// @namespace			WebM Inline Player by Faberman
// @description     	Automatically replaces links to WebM files with embedded videos
// @include     		http://*
// @include     		https://*
// @exclude				*.4chan.org/*
// @exclude				*.reddit.com/*
// @require           	https://openuserjs.org/src/libs/sizzle/GM_config.js
// @require				https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js
// @grant              	GM_getValue
// @grant             	GM_setValue
// @grant              	GM_log
// @grant          		GM_xmlhttpRequest
// @grant          		GM_registerMenuCommand
// @grant          		GM_addStyle
// ==/UserScript==

;(function($,window,document,undefined){var Scroller=function(videos){this.init(videos);};Scroller.prototype.init=function(videos){this.data=[];videos.each($.proxy(function(i,elem){this.add($(elem));},this));videos.on('loadedmetadata',$.proxy(function(){this.scrolled();},this));};Scroller.prototype.add=function($elem){var t=$elem.offset().top;this.data.push({$elem:$elem,});};Scroller.prototype.scrolled=function(){var $window=$(window);var t=$window.scrollTop();var b=t+$window.innerHeight();$.each($.map(this.data,function(obj,i){var h=obj.$elem.innerHeight();var top=obj.$elem.offset().top;var bottom=top+h;var p=0;if(top<=b&&bottom>=t){if(bottom>b){p=(b-top)/h;}else if(top<t){p=(bottom-t)/h;}else{p=1;}}
return{p:p,t:top,node:obj.$elem[0]};}).sort(function(a,b){if(a.p>b.p){return-1;}else if(a.p<b.p){return 1;}
if(a.t<b.t){return-1;}else if(a.t>b.t){return 1;}
return 0;}),function(i,obj){if(i===0&&obj.p==1.0){obj.node.play();}else{obj.node.pause();}});};Scroller.prototype.resized=function(){$.each(this.data,function(i,obj){obj.top=obj.$elem.offset().top;obj.bottom=obj.top+obj.$elem.height();});this.scrolled();};Scroller.prototype.listen=function(){var $window=$(window);$window.on('scroll',$.proxy(function(){if(this.data.length===0){return false;}
this.scrolled();},this));$window.on('resize',$.proxy(function(){if(this.data.length===0){return false;}
this.resized();},this));};$.fn.scrollplay=function(){var scroller=new Scroller(this);scroller.listen();return this;};})(jQuery,window,document);

var cfgFrame = "bottom: auto; background: #f0f0f0; border: 1px solid #cacaca; width: 470px; height: 470px; margin: 0 auto; border-radius: 5px; -moz-border-radius: 5px; -webkit-border-radius: 5px;" + "max-height: 95%; max-width: 95%; opacity: 1;" + "overflow: auto; padding: 10px; position: fixed;" + "z-index: 999; display: block;";

var cssHeaderLogo = "url('')";

var cfgCss = [
"#Config_Logo {background-image:" + cssHeaderLogo + "; background-repeat: no-repeat; 	background-position: center;}",
"#GM_config {background: #f0f0f0;}",
//	"#GM_config_section_header_0 {height: 23px; line-height: 23px; vertical-align: middle;}",
"#GM_config .section_header {font-weight: bold; background: none repeat scroll 0% 0% #333; border-style: none !important; margin-bottom: 15px !important; margin-top: 15px !important;}",
//	"#GM_config .config_var {margin: 0px 0px 15px;}",
"#GM_config .field_label {font-size: 14px !important; font-family: 'Segoe UI', 'Droid Sans Fallback', 'Tahoma', sans-serif; color: #303942;}",
"#GM_config .radio_label {font-size: 14px !important; margin-right: 20px !important;}",
"#GM_config_HideControls_field_label {margin-left: 6px !important;}",
"#GM_config_Loop_field_label {margin-left: 6px !important;}",
"#GM_config_Mute_field_label {margin-left: 6px !important;}",
//	"#GM_config_Width_field_label {margin-right: 20px !important;}",
//	"#GM_config_Height_field_label {margin-right: 15px !important;}",
//	"#GM_config_HideControls_var {border-bottom: 1px solid #DADADA; padding-bottom: 15px;}",
//	"#GM_config_Mute_var {border-bottom: 1px solid #DADADA; padding-bottom: 15px;}",
//	"#GM_config_Height_var {border-bottom: 1px solid #DADADA; padding-bottom: 15px;}",
"#GM_config_buttons_holder {text-align: center;}", "#GM_config .saveclose_buttons {cursor: pointer;}",
"#GM_config .section_header_holder {text-align: center; margin-top: 0 !important;}",
"#GM_config_Loop_var, #GM_config_Mute_var, #GM_config_Width_var, #GM_config_Height_var {display: inline-block; margin: 0 7%!important;}",
"#GM_config_HideControls_var {margin-bottom: 15px !important;}",
"#GM_config_PlayMode_var {margin-bottom: 10px !important;}",
"#GM_config_section_header_1, #GM_config_section_header_3 {font-size: 3px !important; color: #aaa !important; background: none repeat scroll 0% 0% #aaa !important}"
].join("\n");

var cfgTitle = document.createElement('div');
cfgTitle.id = "Config_Logo";
cfgTitle.style.cssText = "margin:0 auto; height: 80px;";

var fieldDefs = {
    'PlayMode': {
        'label': 'Play Videos:',
        'section': ['Options'],
        'type': 'radio',
        'options': ['On Click', 'On Mouseover', 'Automatically on Scroll'],
        'default': 'On Click'
    },
    'HideControls': {
        'label': 'Hide Video Controls',
        'labelPos': 'right',
        'type': 'checkbox',
        'title': 'In "On Click" and "Auto" modes (click on any part of the video to start/pause playback)',
        'default': false
    },
    'Loop': {
        'label': 'Loop Videos',
        'section': ['Default behavior'],
        //		'labelPos': 'right',
        'type': 'checkbox',
        'default': false
    },
    'Mute': {
        'label': 'Disable Sound',
        //		'labelPos': 'right',
        'type': 'checkbox',
        'default': false
    },
    'Width': {
        'label': 'Width:',
        'section': ['Maximum size of the video player'],
        'type': 'int',
        'size': 5,
        'title': 'Set the maximum width of a video',
        'default': 500
    },
    'Height': {
        'label': 'Height:',
        'type': 'int',
        'size': 5,
        'title': 'Set the maximum height of a video',
        'default': 500
    },
    'Hidden': {
        'type': 'hidden',
        'section': ['Hidden'],
        'default': ''
    }
};

GM_config.init({
    id: 'GM_config',
    title: cfgTitle,
    fields: fieldDefs,
    css: cfgCss,
    events: {
        'save': function() {
            configSave();
        }
    }
});

function configSave() {
    GM_config.close();
    location.reload();
}

function showOptions() {
    GM_config.open();
    GM_config.frame.setAttribute('style', cfgFrame);
}

GM_registerMenuCommand('Set up WebM Inline Player', showOptions);

(function showWebM() {

    var video_links = document.querySelectorAll('a'),
        url, video;

    for (var i = 0; i < video_links.length; i++) {
        url = video_links[i].href;
        if (video_links[i].href.match(/\.webm$/i)) {
            video = document.createElement('video');
            video.src = url;
            video.loop = GM_config.get('Loop');
            video.muted = GM_config.get('Mute');
            video.style.maxWidth = GM_config.get('Width') + 'px';
            video.style.maxHeight = GM_config.get('Height') + 'px';
            video.preload = "metadata";

            video_links[i].parentNode.replaceChild(video, video_links[i]);

            video.addEventListener('ended', function() {
                this.currentTime = 0;
            });

            if (GM_config.get('PlayMode') == 'On Click' || GM_config.get('PlayMode') == 'Automatically on Scroll') {
                video.controls = true;
            }

            if (GM_config.get('HideControls') == true || GM_config.get('PlayMode') == 'On Mouseover') {
                video.controls = false;
            }

            if (GM_config.get('HideControls') == true) {
                video.addEventListener('click', function(event) {
                    if (this.paused) {
                        this.play();
                    } else {
                        this.pause();
                    }
                });
            }

            if (GM_config.get('PlayMode') == 'On Mouseover') {
                video.addEventListener('mouseover', function(event) {
                    this.play();
                });
                video.addEventListener('mouseout', function(event) {
                    this.pause();
                });
            }

        }
    }

    if (GM_config.get('PlayMode') == 'Automatically on Scroll') {
        $('video').scrollplay();
    }

})();