MediaWiki:Common.js : Différence entre versions

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. */
  
/*Favicon*/
+
/* =====================================
 +
DECLARATIONS DES FONCTIONS ET PROCEDURES
 +
======================================== */
  
$('link[rel="shortcut icon"]').attr('href', 'https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico');
+
/* Favicon */
 
+
function fixInsecureFavicon() {
/*Tabber*/
+
  document.querySelector('link[rel="shortcut icon"]').href = "https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico";
 
 
function onTabClick(){
 
 
 
  var parent = this.parentElement;
 
  var buttonList = parent.children;
 
  var contentList = parent.nextElementSibling.children;
 
  var position = this.dataset.position; // position du bouton sélectionné
 
  var activeButton = parent.querySelector(".tabber-active");
 
 
 
  if (activeButton == null) {
 
   
 
    this.classList.add("tabber-active");
 
    contentList[position].classList.add("tabber-active");
 
   
 
  } else {
 
   
 
    var activePosition = activeButton.dataset.position; // position du bouton actif
 
   
 
    if (activePosition == position) {
 
     
 
      // lorsque la fonction est appelé par le target
 
      if (event.currentTarget==this) {
 
       
 
        this.classList.remove("tabber-active");
 
        contentList[position].classList.remove("tabber-active");
 
      }
 
     
 
    } else {
 
 
      this.classList.add("tabber-active");
 
      contentList[position].classList.add("tabber-active");
 
     
 
      activeButton.classList.remove("tabber-active");
 
      contentList[activePosition].classList.remove("tabber-active");
 
    }
 
  }
 
}
 
 
 
function buttonTabber(content){
 
 
 
  var buttonList = content.querySelectorAll(".button");
 
  var targetButton = content.querySelector(".button:target");
 
   
 
  buttonList.forEach(function(button) {
 
     
 
    button.addEventListener("click", onTabClick, false);
 
  });
 
 
 
  if (targetButton !== null) {
 
    onTabClick.call(targetButton);
 
  }
 
}
 
 
 
/*Calcul*/
 
 
 
function createInput(content){
 
 
 
  //sélectionne toutes les div contenant les futurs input
 
  var allInput = content.querySelectorAll("div#inputCalcul");
 
 
 
  //sélectionne les div qui contiendront les input du résultat du calcul
 
  var resultatCalc = content.querySelectorAll("div#inputResult");
 
 
 
  //parcourt tous les input
 
  allInput.forEach(function(e){
 
   
 
    //insert les input à l'intérieur des associées
 
    e.insertAdjacentHTML('afterbegin','<input id="entree" type="number" required>');
 
  });
 
 
 
  //parcourt les input résultat
 
  resultatCalc.forEach(function(e){
 
   
 
    //insert les input résultat à l'intérieur des div associées
 
    e.insertAdjacentHTML('afterbegin','<input id="sortie" type="number" required>');
 
  });
 
}
 
 
 
function formule(tabValue,tabCoeff,formuleNumber){
 
 
 
  if(formuleNumber === 0){
 
   
 
    var value = 0;
 
    var n = tabValue.length;
 
   
 
    if (n*(n+1)/2 != tabCoeff.length){
 
      return 0;
 
    } else {
 
      var c = 0;
 
      for(var i=0; i < n; i++){
 
        for(var j=0; j < n-i; j++){
 
          value += parseFloat(tabCoeff[c])*tabValue[i]*tabValue[i+j];
 
          c += 1;
 
        }
 
      }
 
      return Math.floor(value);
 
    }
 
  } else {
 
    switch(formuleNumber) {
 
      case 1:
 
        return 0;
 
    }
 
  }
 
 
}
 
}
  
function calculWiki(content){
+
/* Modal */
 +
function createModalInteraction(content){
 
    
 
    
  //sélectionne la div qui contient les coefficients de la formule
 
  var coeffDOM = content.querySelector("div#coeffFormule");
 
   
 
  if (coeffDOM != null){
 
     
 
    //crée le tableau des coefficients de la formule
 
    var tabCoeff = coeffDOM.textContent.split(",");
 
     
 
  } else {
 
   
 
    //sélectionne le numéro de la formule à utiliser
 
    var formuleNumberDOM = content.querySelector("div#formuleNumber");
 
    var formuleNumber = parseInt(formuleNumberDOM.textContent);
 
  }
 
 
  //séléectionne le bouton assoicié aux calculs
 
  var bouttonCalcul = content.querySelector("#buttonCalcul");
 
 
 
  //exécute une fonction à chaque clic sur le bouton
 
  bouttonCalcul.addEventListener("click", function(){
 
   
 
    var value = 0;
 
   
 
    //sélectionne tous les input d'entrée
 
    var allRealInput = content.querySelectorAll("input#entree");
 
   
 
    //sélectionne tous les input de sortie
 
    var allRealInputOut = content.querySelectorAll("input#sortie");
 
   
 
    var tableauInput = [1];
 
 
    //stocke toutes les valeurs des inputs dans tableauInput
 
    allRealInput.forEach(function(e){
 
      if (e.value != ""){
 
        tableauInput.push(parseFloat((e.value)));
 
      }
 
    });
 
   
 
    if(tabCoeff != undefined){
 
      value = formule(tableauInput,tabCoeff,0);
 
    } else {
 
      value = formule(tableauInput,[],formuleNumber);
 
    }
 
   
 
    //parcourt tous les input de sortie en leur donnant la valeur calculée précédemment
 
    allRealInputOut.forEach(function(e){
 
      e.value=value;
 
    });
 
  }); 
 
}
 
 
/*Modal*/
 
 
function modal(content){
 
 
 
  //sélectionne le bouton, le modal et le close à l'intérieur de l'id modalContainer
 
 
   var boutonModal = content.querySelector(".button");
 
   var boutonModal = content.querySelector(".button");
 
   var modalContent = content.querySelector(".modal");
 
   var modalContent = content.querySelector(".modal");
 
   var boutonClose = content.querySelector(".close");
 
   var boutonClose = content.querySelector(".close");
 
    
 
    
  //exécute la fonction suivante lorsqu'on clique sur le bouton
 
 
   boutonModal.addEventListener("click", function(){
 
   boutonModal.addEventListener("click", function(){
   
 
    //ajoute la classe active au bouton
 
 
     boutonModal.className += " tabber-active";
 
     boutonModal.className += " tabber-active";
   
 
    //affiche le modal
 
 
     modalContent.style.display = "block";
 
     modalContent.style.display = "block";
 
      
 
      
    //ferme le modal lorsqu'on clique sur le bouton close
 
 
     boutonClose.addEventListener("click", function(){
 
     boutonClose.addEventListener("click", function(){
 
       modalContent.style.display = "none";
 
       modalContent.style.display = "none";
       boutonModal.className = boutonModal.className.replace("tabber-active", "")
+
       boutonModal.className = boutonModal.className.remove("tabber-active");
 
     });
 
     });
 
      
 
      
    //ferme le modal lorsqu'on clique en dehors du modal
 
 
     window.addEventListener("click", function(e){
 
     window.addEventListener("click", function(e){
 
       if (e.target == modalContent) {
 
       if (e.target == modalContent) {
 
         modalContent.style.display = "none";
 
         modalContent.style.display = "none";
         boutonModal.className = boutonModal.className.replace("tabber-active", "")
+
         boutonModal.className = boutonModal.className.remove("tabber-active");
 
       }
 
       }
 
     });
 
     });
Ligne 198 : Ligne 35 :
 
}
 
}
  
/*switch de contenu*/
+
/* CHANGEMENT DE CONTENU */
 
 
 
function switchDiv(content){
 
function switchDiv(content){
 
    
 
    
  //sélectionne le bouton à l'intérieur de l'id buttonContainer
 
 
   var boutonSwitch = content.querySelector(".button");
 
   var boutonSwitch = content.querySelector(".button");
 
    
 
    
  //exécute la fonction suivante à chaque clique sur le bouton
 
 
   boutonSwitch.addEventListener("click", function(){
 
   boutonSwitch.addEventListener("click", function(){
 
      
 
      
    //sélectionne toutes les div avec l'id change
 
 
     var changeDiv = content.querySelectorAll("div#change");
 
     var changeDiv = content.querySelectorAll("div#change");
 
     var n = changeDiv.length;
 
     var n = changeDiv.length;
 
      
 
      
    //fais disparaître la div affichée et fais apparaître la div suivante
 
 
     for (var i = 0; i < n; i++) {
 
     for (var i = 0; i < n; i++) {
 
       if(getComputedStyle(changeDiv[i]).display == "block") {
 
       if(getComputedStyle(changeDiv[i]).display == "block") {
Ligne 229 : Ligne 61 :
 
function changeDisplay(content){
 
function changeDisplay(content){
 
    
 
    
  //sélectionne le bouton à l'intérieur de l'id buttonContainer
 
 
   var boutonSwitch = content.querySelector(".button");
 
   var boutonSwitch = content.querySelector(".button");
 
 
 
   var frereList = content.nextElementSibling;
 
   var frereList = content.nextElementSibling;
 
    
 
    
  //exécute la fonction suivante à chaque clique sur le bouton
 
 
   boutonSwitch.addEventListener("click", function(){
 
   boutonSwitch.addEventListener("click", function(){
 
     if (this.classList.length == 1) {
 
     if (this.classList.length == 1) {
Ligne 246 : Ligne 75 :
 
}
 
}
  
 +
/* Liste des monstres */
 
function init(list){
 
function init(list){
 
   list.forEach(function(el){
 
   list.forEach(function(el){
Ligne 284 : Ligne 114 :
 
}
 
}
  
 +
/* BOUTON RETOUR VERS LE HAUT */
 
function addButtonTop() {
 
function addButtonTop() {
 
    
 
    
Ligne 300 : Ligne 131 :
 
   var balise = document.querySelector("div#mw-page-header-links");
 
   var balise = document.querySelector("div#mw-page-header-links");
 
   var topButton = document.querySelector(".top-button");
 
   var topButton = document.querySelector(".top-button");
 
+
 
   var options = {
+
   if (balise !== null) {
    root: null,
+
    var options = {
 +
      root: null,
 
       rootMargin: "0px",
 
       rootMargin: "0px",
 
       threshold: 0,
 
       threshold: 0,
  };
+
    };
 
    
 
    
  var observer = new IntersectionObserver(callback, options);
+
    var observer = new IntersectionObserver(callback, options);
  observer.observe(balise);
+
    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({
+
/* Cookies */
      top: 0
+
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();
 
}
 
}
  
//s'exécute une fois au chargement de chaque page
+
/* =======================================
 +
FONCTION GLOBALE
 +
Exécutée une fois au chargement de la page
 +
========================================== */
 +
 
 
(function(){
 
(function(){
 +
  fixInsecureFavicon()
 
    
 
    
  //sélectionne toutes les div contenant un tabber à l'intérieur du contenu de chaque page
 
  var tabberContainer = document.querySelectorAll("div#mw-content-text div.tabber-container");
 
 
 
  //parcourt chaque div contenant un tabber, rien si vide
 
  tabberContainer.forEach(function(e){
 
   
 
    //exécute la fonction buttonTabber
 
    buttonTabber(e);
 
    });
 
 
 
  //sélectionne toutes les div contenant un calcul à l'intérieur du contenu de chaque page
 
  var containerCalcul = document.querySelectorAll("div#mw-content-text div#container-calcul");
 
 
 
  //parcourt chaque div contenant un calcul, rien si vide
 
  containerCalcul.forEach(function(e){
 
   
 
    //exécute les fonctions createInput et calculWiki
 
    createInput(e);
 
    calculWiki(e);
 
  });
 
 
 
  //sélectionne toutes les div contenant un modal à l'intérieur du contenu de chaque page
 
 
   var modalContainer = document.querySelectorAll("div#mw-content-text div#modalContainer");
 
   var modalContainer = document.querySelectorAll("div#mw-content-text div#modalContainer");
 
 
  //parcourt chaque div contenant un modal, rien si vide
 
 
   modalContainer.forEach(function(e){
 
   modalContainer.forEach(function(e){
      
+
     createModalInteraction(e);
    //exécute la fonction modal
 
    modal(e);
 
 
   });
 
   });
 
    
 
    
  //sélectionne toutes les div contenant un bouton pour switch à l'intérieur du contenu de chaque page
 
 
   var bcontainer = document.querySelectorAll("div#mw-content-text #buttonContainer");  
 
   var bcontainer = document.querySelectorAll("div#mw-content-text #buttonContainer");  
 
 
  //parcourt chaque div contenant un bouton pour switch, rien si vide
 
 
   bcontainer.forEach(function(e){
 
   bcontainer.forEach(function(e){
   
 
    //exécute la fonction switchDiv
 
 
     switchDiv(e);
 
     switchDiv(e);
 
   });
 
   });
  
 
   var ccontainer = document.querySelectorAll("div#mw-content-text .list-equip");
 
   var ccontainer = document.querySelectorAll("div#mw-content-text .list-equip");
 
 
 
   ccontainer.forEach(function(e){
 
   ccontainer.forEach(function(e){
   
 
 
     changeDisplay(e);
 
     changeDisplay(e);
 
   });
 
   });
  
 
   var mobContainers = document.querySelectorAll("div#mw-content-text div.mob-container");
 
   var mobContainers = document.querySelectorAll("div#mw-content-text div.mob-container");
 
 
 
   mobContainers.forEach( function(mobContainer) {
 
   mobContainers.forEach( function(mobContainer) {
 
     displayTableMob(mobContainer)
 
     displayTableMob(mobContainer)
 
   });
 
   });
  
  addButtonTop();
+
   var loadScripts = document.querySelectorAll("div[data-load-javascript]");
  buttonTop();
 
 
 
   var skillContainer = document.querySelector("div#mw-content-text div.skill-container");
 
 
    
 
    
   if (skillContainer !== null) {
+
   /* Charge des scripts spécifiques au chargement de certaines pages */
    mw.loader.load("/index.php?title=MediaWiki:Script/Skills.js&action=raw&ctype=text/javascript");
+
  if (loadScripts.length) {
  }
+
     var checkArray = new Array(0);
})();
+
     loadScripts.forEach(function(loadScript){
 
+
      script = loadScript.dataset["loadJavascript"];
/* Pour les cookies */
+
      if (checkArray.indexOf(script) === -1) {
 
+
        checkArray.push(script);
(function () {
+
        switch (script) {
     var req = new XMLHttpRequest();
+
          case "tabber" : // charge le script pour utiliser les tabber
     req.addEventListener('load', function (ev) {
+
            mw.loader.load("/index.php?title=MediaWiki:Script/Tabber.js&action=raw&ctype=text/javascript");
        if (this.status >= 200 && this.status < 300) {
+
            break;
            var data = JSON.parse(this.responseText);
+
          case "skills" : // charge le script pour utiliser le simulateur de compétence
            if (data.hasOwnProperty('version')) {
+
            mw.loader.load("/index.php?title=MediaWiki:Script/Skills.js&action=raw&ctype=text/javascript");
                var gdpr = document.createElement("script");
+
             break;
                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();
+
 
 +
  addButtonTop();
 +
  buttonTop();
 +
  cookies()
 
})();
 
})();

Version du 12 mai 2022 à 11:30

/* 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";
}

/* Modal */
function createModalInteraction(content){
  
  var boutonModal = content.querySelector(".button");
  var modalContent = content.querySelector(".modal");
  var boutonClose = content.querySelector(".close");
  
  boutonModal.addEventListener("click", function(){
    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 */
function switchDiv(content){
  
  var boutonSwitch = content.querySelector(".button");
  
  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 boutonSwitch = content.querySelector(".button");
  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 init(list){
  list.forEach(function(el){
    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 */
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();
}

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

(function(){
  fixInsecureFavicon()
  
  var modalContainer = document.querySelectorAll("div#mw-content-text div#modalContainer");
  modalContainer.forEach(function(e){
    createModalInteraction(e);
  });
  
  var bcontainer = document.querySelectorAll("div#mw-content-text #buttonContainer"); 
  bcontainer.forEach(function(e){
    switchDiv(e);
  });

  var ccontainer = document.querySelectorAll("div#mw-content-text .list-equip");
  ccontainer.forEach(function(e){
    changeDisplay(e);
  });

  var mobContainers = document.querySelectorAll("div#mw-content-text div.mob-container");
  mobContainers.forEach( function(mobContainer) {
    displayTableMob(mobContainer)
  });

  var loadScripts = document.querySelectorAll("div[data-load-javascript]");
  
  /* Charge des scripts spécifiques au chargement de certaines pages */
  if (loadScripts.length) {
    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;
        }
      }
    });
  }
  
  addButtonTop();
  buttonTop();
  cookies()
})();