MediaWiki:Common.js : Différence entre versions

(ajout slideshow)
 
(87 révisions intermédiaires par 3 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
/* Tout JavaScript ici sera chargé avec chaque page accédée par n’importe quel utilisateur. */
+
/* Tout le JavaScript ici sera chargé avec chaque page accédée par n’importe quel utilisateur. */
  
$('div#content').append( "<div class='content-footer'></div>" );
+
/* =====================================
 +
DECLARATIONS DES FONCTIONS ET PROCEDURES
 +
======================================== */
  
(function () {
+
/* Favicon */
 +
function fixInsecureFavicon() {
 +
    document.querySelector('link[rel="shortcut icon"]').href = "https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico";
 +
}
 +
 
 +
/* Liste des équipements */
 +
function changeDisplay(content) {
 +
    var boutonSwitch = content.querySelector(".button");
 +
    var frereList = content.nextElementSibling;
 +
 
 +
    boutonSwitch.addEventListener("click", function () {
 +
        this.classList.toggle('tabber-active');
 +
        frereList.classList.toggle('tabber-noactive');
 +
    });
 +
}
 +
 
 +
/* BOUTON RETOUR VERS LE HAUT */
 +
function addButtonTop() {
 +
    var contentText = document.querySelector("div#mw-content-text");
 +
 
 +
    if (contentText !== null) {
 +
 
 +
        var divButtonTop = document.createElement("div");
 +
        divButtonTop.classList.add("top-button");
 +
        contentText.appendChild(divButtonTop);
 +
    }
 +
}
 +
 
 +
function buttonTop() {
 +
    var balise = document.querySelector("div#mw-page-header-links");
 +
    var topButton = document.querySelector(".top-button");
 +
 
 +
    if (balise !== null) {
 +
        var options = {
 +
            root: null,
 +
            rootMargin: "0px",
 +
            threshold: 0,
 +
        };
 +
 
 +
        var observer = new IntersectionObserver(callback, options);
 +
        observer.observe(balise);
 +
 
 +
        function callback(entries) {
 +
            entries.forEach(function (entry) {
 +
                if (entry.isIntersecting) {
 +
                    topButton.classList.remove("show-button");
 +
                } else {
 +
                    topButton.classList.add("show-button");
 +
                }
 +
            });
 +
        }
 +
 
 +
        topButton.addEventListener("click", function () {
 +
            document.documentElement.scrollTo({
 +
                top: 0
 +
            });
 +
        });
 +
    }
 +
}
 +
 
 +
/* Cookies */
 +
function cookies() {
 
     var req = new XMLHttpRequest();
 
     var req = new XMLHttpRequest();
 
     req.addEventListener('load', function (ev) {
 
     req.addEventListener('load', function (ev) {
Ligne 17 : Ligne 80 :
 
     req.open('GET', "https://s3-static.geo.gfsrv.net/cookiebanner/version.json");
 
     req.open('GET', "https://s3-static.geo.gfsrv.net/cookiebanner/version.json");
 
     req.send();
 
     req.send();
})();
+
}
 +
 
 +
 
 +
function addScript(src, callback) {
 +
    var script = document.createElement('script');
 +
    script.src = src;
 +
 
 +
    function onComplete() {
 +
        if (script.parentNode) {
 +
            script.parentNode.removeChild(script);
 +
        }
 +
        if (callback) {
 +
            callback();
 +
            callback = null;
 +
        }
 +
    }
 +
 
 +
    script.onload = onComplete;
 +
    script.onerror = onComplete;
 +
 
 +
    document.head.appendChild(script);
 +
}
 +
 
 +
/* =======================================
 +
FONCTION GLOBALE
 +
Exécutée une fois au chargement de la page
 +
========================================== */
 +
 
 +
(function () {
 +
    fixInsecureFavicon()
 +
 
 +
    var equipmentContainer = document.querySelectorAll('div#mw-content-text .list-equip');
 +
    var loadScripts = document.querySelectorAll('div[data-load-javascript]');
 +
 
 +
    equipmentContainer.forEach(function (container) {
 +
        changeDisplay(container);
 +
    });
 +
 
 +
    /* Charge des scripts spécifiques au chargement de certaines pages */
 +
    if (loadScripts.length > 0) {
 +
 
 +
        var allowedScripts = ["Tabber", "Skills", "Modal", "Switch", "Loot", "Map", "Filter", "Calculator", "Element", "Pets"];
 +
        var scriptsToLoad = [];
 +
 
 +
        for (var i = 0; i < loadScripts.length; i++) {
 +
 
 +
            var script = loadScripts[i].dataset['loadJavascript'];
 +
 
 +
            if ((allowedScripts.indexOf(script) !== -1) && (scriptsToLoad.indexOf(script) === -1)) {
 +
                scriptsToLoad.push(script);
 +
            }
 +
        }
 +
 
 +
        function loadNextScript() {
 +
            if (scriptsToLoad.length > 0) {
 +
                var script = scriptsToLoad.shift();
 +
                addScript("/index.php?title=MediaWiki:Script/" + script + ".js&action=raw&ctype=text/javascript", loadNextScript);
 +
            }
 +
        }
  
 +
        loadNextScript();
 +
    }
  
 +
    if (mw.config.get("wgUserName")) {
 +
        mw.loader.load("/index.php?title=MediaWiki:Script/Redactor.js&action=raw&ctype=text/javascript");
 +
    }
  
/* Slideshow pour faire défiler les images, c'est du JS pompé sur le wiki italien */
+
    addButtonTop();
(function() {
+
    buttonTop();
+
    cookies()
function Slideshow( element ) {
 
this.el = document.querySelector( element );
 
this.init();
 
}
 
 
Slideshow.prototype = {
 
init: function() {
 
this.wrapper = this.el.querySelector( ".slider-wrapper" );
 
this.slides = this.el.querySelectorAll( ".slide" );
 
this.previous = this.el.querySelector( ".slider-previous" );
 
this.next = this.el.querySelector( ".slider-next" );
 
this.index = 0;
 
this.total = this.slides.length;
 
 
this.actions();
 
},
 
_slideTo: function( slide ) {
 
var currentSlide = this.slides[slide];
 
currentSlide.style.display="block";
 
 
for( var i = 0; i < this.slides.length; i++ ) {
 
var slide = this.slides[i];
 
if( slide !== currentSlide ) {
 
slide.style.display="none";
 
}
 
}
 
},
 
actions: function() {
 
var self = this;
 
self.next.addEventListener( "click", function() {
 
self.index++;
 
self.previous.style.display = "block";
 
 
if( self.index == self.total - 1 ) {
 
self.index = self.total - 1;
 
self.next.style.display = "none";
 
}
 
if (self.index > self.total) {self.index = self.total}
 
if (self.index < 1) {self.index = 1}
 
self._slideTo( self.index );
 
 
}, false);
 
 
self.previous.addEventListener( "click", function() {
 
self.index--;
 
self.next.style.display = "block";
 
 
if( self.index == 0 ) {
 
self.index = 0;
 
self.previous.style.display = "none";
 
}
 
 
self._slideTo( self.index );
 
 
}, false);
 
}
 
 
};
 
document.addEventListener( "DOMContentLoaded", function() {
 
 
var slider = new Slideshow( "#main-slider" );
 
});
 
 
})();
 
})();

Version actuelle datée du 15 juin 2024 à 10:49

/* Tout le JavaScript ici sera chargé avec chaque page accédée par n’importe quel utilisateur. */

/* =====================================
DECLARATIONS DES FONCTIONS ET PROCEDURES
======================================== */

/* Favicon */
function fixInsecureFavicon() {
    document.querySelector('link[rel="shortcut icon"]').href = "https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico";
}

/* Liste des équipements */
function changeDisplay(content) {
    var boutonSwitch = content.querySelector(".button");
    var frereList = content.nextElementSibling;

    boutonSwitch.addEventListener("click", function () {
        this.classList.toggle('tabber-active');
        frereList.classList.toggle('tabber-noactive');
    });
}

/* BOUTON RETOUR VERS LE HAUT */
function addButtonTop() {
    var contentText = document.querySelector("div#mw-content-text");

    if (contentText !== null) {

        var divButtonTop = document.createElement("div");
        divButtonTop.classList.add("top-button");
        contentText.appendChild(divButtonTop);
    }
}

function buttonTop() {
    var balise = document.querySelector("div#mw-page-header-links");
    var topButton = document.querySelector(".top-button");

    if (balise !== null) {
        var options = {
            root: null,
            rootMargin: "0px",
            threshold: 0,
        };

        var observer = new IntersectionObserver(callback, options);
        observer.observe(balise);

        function callback(entries) {
            entries.forEach(function (entry) {
                if (entry.isIntersecting) {
                    topButton.classList.remove("show-button");
                } else {
                    topButton.classList.add("show-button");
                }
            });
        }

        topButton.addEventListener("click", function () {
            document.documentElement.scrollTo({
                top: 0
            });
        });
    }
}

/* Cookies */
function cookies() {
    var req = new XMLHttpRequest();
    req.addEventListener('load', function (ev) {
        if (this.status >= 200 && this.status < 300) {
            var data = JSON.parse(this.responseText);
            if (data.hasOwnProperty('version')) {
                var gdpr = document.createElement("script");
                gdpr.src = "https://s3-static.geo.gfsrv.net/cookiebanner/" + data.version + "/cookie.min.js";
                document.head.appendChild(gdpr);
            }
        }
    });
    req.open('GET', "https://s3-static.geo.gfsrv.net/cookiebanner/version.json");
    req.send();
}


function addScript(src, callback) {
    var script = document.createElement('script');
    script.src = src;

    function onComplete() {
        if (script.parentNode) {
            script.parentNode.removeChild(script);
        }
        if (callback) {
            callback();
            callback = null;
        }
    }

    script.onload = onComplete;
    script.onerror = onComplete;

    document.head.appendChild(script);
}

/* =======================================
FONCTION GLOBALE
Exécutée une fois au chargement de la page
========================================== */

(function () {
    fixInsecureFavicon()

    var equipmentContainer = document.querySelectorAll('div#mw-content-text .list-equip');
    var loadScripts = document.querySelectorAll('div[data-load-javascript]');

    equipmentContainer.forEach(function (container) {
        changeDisplay(container);
    });

    /* Charge des scripts spécifiques au chargement de certaines pages */
    if (loadScripts.length > 0) {

        var allowedScripts = ["Tabber", "Skills", "Modal", "Switch", "Loot", "Map", "Filter", "Calculator", "Element", "Pets"];
        var scriptsToLoad = [];

        for (var i = 0; i < loadScripts.length; i++) {

            var script = loadScripts[i].dataset['loadJavascript'];

            if ((allowedScripts.indexOf(script) !== -1) && (scriptsToLoad.indexOf(script) === -1)) {
                scriptsToLoad.push(script);
            }
        }

        function loadNextScript() {
            if (scriptsToLoad.length > 0) {
                var script = scriptsToLoad.shift();
                addScript("/index.php?title=MediaWiki:Script/" + script + ".js&action=raw&ctype=text/javascript", loadNextScript);
            }
        }

        loadNextScript();
    }

    if (mw.config.get("wgUserName")) {
        mw.loader.load("/index.php?title=MediaWiki:Script/Redactor.js&action=raw&ctype=text/javascript");
    }

    addButtonTop();
    buttonTop();
    cookies()
})();