MediaWiki:Common.js : Différence entre versions

 
(8 révisions intermédiaires par le même utilisateur non affichées)
Ligne 7 : Ligne 7 :
 
/* Favicon */
 
/* Favicon */
 
function fixInsecureFavicon() {
 
function fixInsecureFavicon() {
  document.querySelector('link[rel="shortcut icon"]').href = "https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico";
+
    document.querySelector('link[rel="shortcut icon"]').href = "https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico";
 
}
 
}
  
/* Modal */
+
/* Liste des équipements */
function createModalInteraction(content){
+
function changeDisplay(content) {
 
+
    var boutonSwitch = content.querySelector(".button");
  var boutonModal = content.querySelector(".button");
+
    var frereList = content.nextElementSibling;
  var modalContent = content.querySelector(".modal");
+
 
  var boutonClose = content.querySelector(".close");
+
    boutonSwitch.addEventListener("click", function () {
 
+
        this.classList.toggle('tabber-active');
  boutonModal.addEventListener("click", function(){
+
        frereList.classList.toggle('tabber-noactive');
    boutonModal.className += " tabber-active";
 
    modalContent.style.display = "block";
 
   
 
    boutonClose.addEventListener("click", function(){
 
      modalContent.style.display = "none";
 
      boutonModal.className = boutonModal.className.remove("tabber-active");
 
 
     });
 
     });
   
 
    window.addEventListener("click", function(e){
 
      if (e.target == modalContent) {
 
        modalContent.style.display = "none";
 
        boutonModal.className = boutonModal.className.remove("tabber-active");
 
      }
 
    });
 
  });
 
 
}
 
}
  
/* CHANGEMENT DE CONTENU */
+
/* BOUTON RETOUR VERS LE HAUT */
function switchDiv(content){
+
function addButtonTop() {
 
+
    var contentText = document.querySelector("div#mw-content-text");
  var boutonSwitch = content.querySelector(".button");
+
 
 
+
     if (contentText !== null) {
  boutonSwitch.addEventListener("click", function(){
 
   
 
    var changeDiv = content.querySelectorAll("div#change");
 
    var n = changeDiv.length;
 
   
 
     for (var i = 0; i < n; i++) {
 
      if(getComputedStyle(changeDiv[i]).display == "block") {
 
        changeDiv[i].style.display="none";
 
        if(i<=n-2) {
 
          changeDiv[i+1].style.display="block";
 
        } else {
 
          changeDiv[0].style.display="block";
 
        }
 
        break;
 
      }
 
    }
 
  });
 
}
 
  
function changeDisplay(content){
+
        var divButtonTop = document.createElement("div");
 
+
        divButtonTop.classList.add("top-button");
  var boutonSwitch = content.querySelector(".button");
+
        contentText.appendChild(divButtonTop);
  var frereList = content.nextElementSibling;
 
 
 
  boutonSwitch.addEventListener("click", function(){
 
    if (this.classList.length == 1) {
 
      this.classList.add('tabber-active');
 
      frereList.classList.remove('tabber-noactive');
 
    } else {
 
      this.classList.remove('tabber-active');
 
      frereList.classList.add('tabber-noactive');
 
 
     }
 
     }
  });
 
 
}
 
}
  
/* Liste des monstres */
+
function buttonTop() {
function init(list){
+
     var balise = document.querySelector("div#mw-page-header-links");
  list.forEach(function(el){
+
    var topButton = document.querySelector(".top-button");
    el.classList.remove("tabber-noactive");
 
  })
 
}
 
 
 
function displayTableMob(content) {
 
 
 
  var allMob = content.querySelectorAll('.card-mob');
 
  var buttons = content.querySelectorAll('div.button');
 
 
 
  init(allMob);
 
 
  buttons.forEach(function(button){
 
      
 
    button.addEventListener("click", function() {
 
      var activeButton = content.querySelector(".button.tabber-active");
 
      if (this === activeButton) {
 
        activeButton.classList.remove("tabber-active");
 
        init(allMob);
 
        return
 
      }
 
      if (activeButton !== null) {
 
        activeButton.classList.remove("tabber-active");
 
      }
 
      init(allMob);
 
      button.classList.add("tabber-active");
 
      var caract = Object.keys(this.dataset)[0]
 
      var value = this.dataset[caract];
 
      allMob.forEach(function(mob){
 
        if (mob.dataset[caract] !== value ) {
 
          mob.classList.add("tabber-noactive");
 
        }
 
      });
 
    });   
 
  });
 
}
 
  
/* BOUTON RETOUR VERS LE HAUT */
+
    if (balise !== null) {
function addButtonTop() {
+
        var options = {
 
+
            root: null,
  var contentText = document.querySelector("div#mw-content-text");
+
            rootMargin: "0px",
 
+
            threshold: 0,
  if (contentText !== null) {
+
        };
   
 
    var divButtonTop = document.createElement("div");
 
    divButtonTop.classList.add("top-button");
 
    contentText.appendChild(divButtonTop);
 
  }
 
}
 
  
function buttonTop() {
+
        var observer = new IntersectionObserver(callback, options);
 
+
        observer.observe(balise);
  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) {
+
        function callback(entries) {
      entries.forEach(function(entry) {
+
            entries.forEach(function (entry) {
        if (entry.isIntersecting) {
+
                if (entry.isIntersecting) {
          topButton.classList.remove("show-button");
+
                    topButton.classList.remove("show-button");
        } else {
+
                } else {
        topButton.classList.add("show-button");
+
                    topButton.classList.add("show-button");
 +
                }
 +
            });
 
         }
 
         }
      });
+
 
 +
        topButton.addEventListener("click", function () {
 +
            document.documentElement.scrollTo({
 +
                top: 0
 +
            });
 +
        });
 
     }
 
     }
 
    topButton.addEventListener("click", function(){
 
      document.documentElement.scrollTo({
 
        top: 0
 
      });
 
    });
 
  }
 
 
}
 
}
  
Ligne 175 : 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);
 
}
 
}
  
Ligne 182 : Ligne 108 :
 
========================================== */
 
========================================== */
  
(function(){
+
(function () {
  fixInsecureFavicon()
+
    fixInsecureFavicon()
 
+
 
  var modalContainer = document.querySelectorAll("div#mw-content-text div#modalContainer");
+
    var equipmentContainer = document.querySelectorAll('div#mw-content-text .list-equip');
  modalContainer.forEach(function(e){
+
     var loadScripts = document.querySelectorAll('div[data-load-javascript]');
     createModalInteraction(e);
+
 
  });
+
    equipmentContainer.forEach(function (container) {
 
+
        changeDisplay(container);
  var bcontainer = document.querySelectorAll("div#mw-content-text #buttonContainer");  
+
    });
  bcontainer.forEach(function(e){
+
 
    switchDiv(e);
+
    /* 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 = [];
  
  var ccontainer = document.querySelectorAll("div#mw-content-text .list-equip");
+
        for (var i = 0; i < loadScripts.length; i++) {
  ccontainer.forEach(function(e){
 
    changeDisplay(e);
 
  });
 
  
  var mobContainers = document.querySelectorAll("div#mw-content-text div.mob-container");
+
            var script = loadScripts[i].dataset['loadJavascript'];
  mobContainers.forEach( function(mobContainer) {
+
 
    displayTableMob(mobContainer)
+
            if ((allowedScripts.indexOf(script) !== -1) && (scriptsToLoad.indexOf(script) === -1)) {
  });
+
                scriptsToLoad.push(script);
 +
            }
 +
        }
  
  var loadScripts = document.querySelectorAll("div[data-load-javascript]");
+
        function loadNextScript() {
 
+
            if (scriptsToLoad.length > 0) {
  /* Charge des scripts spécifiques au chargement de certaines pages */
+
                var script = scriptsToLoad.shift();
  if (loadScripts.length) {
+
                addScript("/index.php?title=MediaWiki:Script/" + script + ".js&action=raw&ctype=text/javascript", loadNextScript);
    var checkArray = new Array(0);
+
             }
    loadScripts.forEach(function(loadScript){
 
      script = loadScript.dataset["loadJavascript"];
 
      if (checkArray.indexOf(script) === -1) {
 
        checkArray.push(script);
 
        switch (script) {
 
          case "tabber" : // charge le script pour utiliser les tabber
 
            mw.loader.load("/index.php?title=MediaWiki:Script/Tabber.js&action=raw&ctype=text/javascript");
 
            break;
 
          case "skills" : // charge le script pour utiliser le simulateur de compétence
 
            mw.loader.load("/index.php?title=MediaWiki:Script/Skills.js&action=raw&ctype=text/javascript");
 
             break;
 
 
         }
 
         }
      }
+
 
     });
+
        loadNextScript();
  }
+
    }
 
+
 
  addButtonTop();
+
     if (mw.config.get("wgUserName")) {
  buttonTop();
+
        mw.loader.load("/index.php?title=MediaWiki:Script/Redactor.js&action=raw&ctype=text/javascript");
  cookies()
+
    }
 +
 
 +
    addButtonTop();
 +
    buttonTop();
 +
    cookies()
 
})();
 
})();

Version actuelle datée du 15 juin 2024 à 11: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()
})();