Welcome to IOPWiki, Commander.
With the release of the new game, we encourage contributions to topics related to Girls' Frontline 2. Learn how to contribute, read the maintenance guide, and join our Discord server to discuss major changes.
If you or someone you know can help deciphering the game files, contact our administrator.

MediaWiki:Gadget-OggPlayer.js: Difference between revisions

Welcome to IOP Wiki. This website is maintained by the Girls' Frontline community and is free to edit by anyone.
Jump to navigation Jump to search
Pianoforte (talk | contribs)
m Pianoforte moved page MediaWiki:OggPlayer.js to MediaWiki:Gadget-OggPlayer.js without leaving a redirect: adding it to gadgets
m Small coding fix
Line 230: Line 230:
         },
         },
         msg: function(code) {
         msg: function(code) {
             var lang = oggPlayer.messages[wgUserLanguage] || oggPlayer.messages[wgContentLanguage] || oggPlayer.messages['en'];
        var langId = 'en';
        if (wgContentLanguage) langId = wgContentLanguage;
        if (wgUserLanguage) langId = wgUserLanguage;
             var lang = oggPlayer.messages[langId];
             return lang[code];
             return lang[code];
         }
         }

Revision as of 20:10, 14 September 2024

(function() {
    var oggPlayer = {
        support: '',
        messages: {
            'en': {
                'play': 'Play',
                'no-audio': 'Invalid or missing audio file',
                'no-support': 'Your browser doesn\'t support Ogg format',
            },
            'qqx': {
                'play': '(play)',
                'no-audio': '(no-audio)',
                'no-support': '(no-support)',
            },
            'de': {
                'play': 'Abspielen',
                'no-audio': 'Ungültige oder fehlende Audiodatei',
                'no-support': 'Dein Browser unterstützt kein Ogg-Format',
            },
            'es': {
                'play': 'Reproducir',
                'no-audio': 'Archivo de audio inválido o faltante',
                'no-support': 'Tu navegador no soporta el formato Ogg',
            },
            'fr': {
                'play': 'Lecture',
                'no-audio': 'Fichier audio introuvable ou invalide',
                'no-support': 'Votre navigateur ne supporte pas le format Ogg',
            },
            'nl': {
                'play': 'Afspelen',
                'no-audio': 'Audiobestand ontbreekt of is ongeldig',
                'no-support': 'Deze browser ondersteunt de Ogg-indeling niet',
            },
            'pl': {
                'play': 'Odtwórz',
                'no-audio': 'Niepoprawny lub brakujący plik audio',
                'no-support': 'Twoja przeglądarka nie ma wsparcia dla formatu Ogg',
            },
        },
        allButtons: $([]),
        init: function() {
            if(typeof oggPlayerButtonOnly == 'undefined') oggPlayerButtonOnly = false;
            oggPlayer.support = document.createElement('audio').canPlayType('audio/ogg');
            oggPlayer.addCSS();
            if(!oggPlayerButtonOnly) $('.ogg_player').each(function() { oggPlayer.prepPlayer($(this)); });
            $('.audio-button').each(function() { oggPlayer.prepButton($(this)); });
            mw.hook('wikipage.content').add(function(elem) {
                if(!oggPlayerButtonOnly) $(elem).find('.ogg_player').each(function() { oggPlayer.prepPlayer($(this)); });
                $(elem).find('.audio-button').each(function() { oggPlayer.prepButton($(this)); });
            });
        },
        addCSS: function() {
            $('head').prepend('<style type="text/css">.audio-button { display: inline-block; vertical-align: text-top; width: 1em; height: 1em; overflow: hidden; border-radius: 1px; background-color: rgba(100,100,100,0.7); transition: background-color .2s; cursor: pointer; background-repeat: no-repeat; background-position: center; background-image: url(\'\'); } .audio-button-parent { cursor: pointer; } .audio-button.now-playing, .audio-button:hover, .audio-button-parent:hover > .click-parent { background-color: #EEAA00; } .audio-button.now-playing { background-image: url(\'\'); } .audio-button.no-audio { cursor: help; background-color: #b30000; background-image: url(\'\'); } .ogg-player audio, .ogg-player video { display: inline-block; } .ogg-player .info-icon { display: none; position: absolute; z-index: 2; background-color: transparent; background-image: url(http://slot1.images.wikia.nocookie.net/__cb1453503614/common/skins/shared/images/sprite.png); background-repeat: no-repeat; background-position: -1228px 0; height: 18px; width: 18px; } .ogg-audio-player .info-icon { background-color: rgba(0, 0, 0, .5); margin: -5px 0 0 -5px; border-radius: 100%; } .ogg-video-player .info-icon { margin: 2px 0 0 -20px; } .ogg-player:hover .info-icon { display: inline-block; }</style>');
        },
        prepPlayer: function(player) {
            if(player.data('url')) return;
            var button = player.find('button[onclick]');
            if(button.length) {
                var onclick = button[0].onclick.toString();
 
                var match, url, width, height, isVideo;
                if(match = onclick.match(/"videoUrl":"((?:\\.|[^"\\])+)"/)) url = match[1].replace('\\x26', '&');
                if(match = onclick.match(/"width":([0-9]+)/)) width = match[1];
                if(match = onclick.match(/"height":([0-9]+)/)) height = match[1];
                if(match = onclick.match(/"isVideo":(true|false)/)) isVideo = match[1] == 'true';
 
                if(isVideo) {
                    oggPlayer.video(player, url, width, height);
                } else {
                    oggPlayer.audio(player, url, width);
                }
            } else {
                var p = player.find('> div > audio, > div > video');
                player
                    .data('url', p.attr('src'))
                    .empty()
                    .append(p);
            }
            player.removeClass('ogg_player').addClass('ogg-player').removeAttr('id');
        },
        prepButton: function(button) {
            if(button.prop('tagName') == 'A' || button.hasClass('no-audio')) return;
            var src = button.data('src'),
                sources = button.find('audio, video, button[onclick], img, a.internal');
 
            if(oggPlayer.support === '') {
                button.attr('title', oggPlayer.msg('no-support')).addClass('no-audio').empty();
                return;
            }
 
            if(typeof src == 'undefined' || !oggPlayer.isValid(src)) {
                sources.each(function(i, v) {
                    v = $(v);
                    if(v.prop('tagName') == 'A') {
                        src = v.attr('href');
                    } else if(v.prop('tagName') == 'BUTTON') {
                        var match, onclick = v[0].onclick.toString();
                        if(match = onclick.match(/"videoUrl":"((?:\\.|[^"\\])+)"/)) src = match[1];
                    } else {
                        src = v.attr('src');
                    }
                    if(oggPlayer.isValid(src)) return false;
                    src = false;
                });
                if(!src) {
                    button.addClass('no-audio').empty().attr('title', oggPlayer.msg('no-audio'));
                    return;
                }
            }
            var link = $('<a />', {
                'class': button.attr('class'),
                'style': button.attr('style'),
                'data-src': button.data('src'),
                'title': oggPlayer.msg('play'),
                'href': src,
            });
            link.click(function(e) {
                e.preventDefault();
                var audio = $(this).find('audio');
                if(audio.prop('paused')) {
                    oggPlayer.stopAllButtons();
                    audio.trigger('play');
                } else {
                    audio.trigger('pause');
                }
                return false;
            });
            button.replaceWith(link);
 
            if(link.hasClass('click-parent')) {
                if(!link.parent().hasClass('audio-button-parent')) {
                    link.parent().addClass('audio-button-parent').click(function(e) {
                        $(this).find('.click-parent').click();
                    });
                } else {
                    link.removeClass('click-parent');
                }
            }
 
            var audio = $('<audio />', {
                src: src,
                preload: 'none',
            }).appendTo(link).on('play', function(e) {
                $(this).parent().addClass('now-playing');
            }).on('pause', function(e) {
                $(this).parent().removeClass('now-playing');
                this.currentTime = 0;
            }).on('ended', function(e) {
                $(this).trigger('pause');
            }).on('error', function(e) {
                $(this).parent().addClass('no-audio').removeClass('now-playing').empty().attr('title', 'err'+oggPlayer.msg('no-audio'));
            });
            oggPlayer.allButtons = oggPlayer.allButtons.add(audio);
        },
        stopAllButtons: function() {
            oggPlayer.allButtons.trigger('pause');
        },
        isValid: function(url) {
            if(url === undefined) return false;
            url = url.replace(/\?.*$/, '');
            if(url.search(/(?:https?:)?(?:\/\/)(?:images|img|static|vignette)\d*\.wikia\.(?:nocookie\.)?(?:net|com)/) < 0 && url.search(/(?:https?:)?(?:\/\/)upload\.wikimedia\.org/) < 0) return false; // Wikia and Wikimedia only
            url = url.replace(/(vignette.*?)(\/revision.*$)/, '$1');
            if(url.search(/\.(ogg|oga|ogv)$/) < 0) return false;
            return true;
        },
        video: function(player, url, width, height) {
            if(!url) return;
            var a = player.find('a.image');
            player.addClass('ogg-video-player')
                .data('url', url)
                .empty()
                .append(
                    $('<video />', {
                        controls : 'controls',
                        width: width,
                        height: height,
                        src: url,
                        preload: 'metadata'
                    })
                    .click(function(){
                        this.paused ? this.play() : this.pause();
                    })
                    .dblclick(function(){
                        if(document.fullscreenEnabled || document.webkitFullscreenEnabled || document.mozFullScreenEnabled || document.msFullscreenEnabled) {
                            if(document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement) {
                                if(document.exitFullscreen) {
                                    document.exitFullscreen();
                                } else if(document.webkitExitFullscreen) {
                                    document.webkitExitFullscreen();
                                } else if(document.mozCancelFullScreen) {
                                    document.mozCancelFullScreen();
                                } else if(document.msExitFullscreen) {
                                    document.msExitFullscreen();
                                }
                            } else {
                                if(this.requestFullscreen) {
                                    this.requestFullscreen();
                                } else if(this.webkitRequestFullscreen) {
                                    this.webkitRequestFullscreen();
                                } else if(this.mozRequestFullScreen) {
                                    this.mozRequestFullScreen();
                                } else if(this.msRequestFullscreen) {
                                    this.msRequestFullscreen();
                                }
                            }
                        }
                    })
                )
                .append($('<a></a>').addClass('info-icon').attr({
                    href: a.attr('href'),
                    title: a.attr('title')
                }));
        },
        audio: function(player, url, width) {
            if(!url) return;
            var a = player.find('a.image');
            player.addClass('ogg-audio-player')
                .data('url', url)
                .empty()
                .append($('<audio />', {
                    controls : 'controls',
                    src: url,
                    preload: 'metadata'
                }).css('width', width))
                .append($('<a></a>').addClass('info-icon').attr({
                    href: a.attr('href'),
                    title: a.attr('title')
                }));
        },
        msg: function(code) {
        	var langId = 'en';
        	if (wgContentLanguage) langId = wgContentLanguage;
        	if (wgUserLanguage) langId = wgUserLanguage;
            var lang = oggPlayer.messages[langId];
            return lang[code];
        }
    };
    $(oggPlayer.init);
})();