MediaWiki:Common.js : Différence entre versions

Ligne 41 : Ligne 41 :
 
     }
 
     }
 
   }
 
   }
 +
}
 +
 +
function boutonTabber(content){
 +
 
 +
  //sélectionne tous les boutons à l'intérieur de tous les tabbers
 +
  var classButton = content.querySelectorAll(".button");
 +
   
 +
    //parcourt chaque bouton
 +
    classButton.forEach(function(event) {
 +
     
 +
      //exécute la fonction onTabClick à chaque clic sur un bouton
 +
      event.addEventListener("click", onTabClick, false);
 +
    });
 
}
 
}
  

Version du 1 novembre 2021 à 21:34

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

/*Favicon*/

$('link[rel="shortcut icon"]').attr('href', 'https://gf1.geo.gfsrv.net/cdn98/191b803adbf82f4b8febe3a2c38c2c.ico');

/*Tabber*/

function onTabClick(event){
  
  //déclaration du frère du bouton recevant un clic
  var tabberFrere = event.currentTarget.parentElement.nextElementSibling;
  
  if(tabberFrere != null){
    
    var tabberParent = tabberFrere.parentElement;
  
    //class du bouton recevant un clic
    var classButton = event.currentTarget.className;

    //sélection de toutes les div affichées
    tabberActive = tabberParent.querySelectorAll("div.tabber-active");

    //parcourt toutes les div affichées
    tabberActive.forEach(function(tab) {

      //la div affichée est cachée si elle est dans le tabber en question
      if (tabberParent===tab.parentElement.parentElement) {
        tab.className = tab.className.replace("tabber-active", "");
      }
    });

    //si le bouton était déjà actif, il reste cacher avec son contenu
    if (classButton.indexOf("tabber-active")===-1) {

      //la bouton cliqué prend la classe active
      event.currentTarget.className += " tabber-active";

      //le contenu associé au bouton prend la classe active
      tabberFrere.children[parseInt(event.currentTarget.id)].className += " tabber-active";
    }
  }
}

function boutonTabber(content){
  
  //sélectionne tous les boutons à l'intérieur de tous les tabbers
  var classButton = content.querySelectorAll(".button");
    
    //parcourt chaque bouton
    classButton.forEach(function(event) {
      
      //exécute la fonction onTabClick à chaque clic sur un bouton
      event.addEventListener("click", onTabClick, false);
    });
}

/*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){
  
  //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 modalContent = content.querySelector(".modal");
  var boutonClose = content.querySelector(".close");
  
  //exécute la fonction suivante lorsqu'on clique sur le bouton
  boutonModal.addEventListener("click", function(){
    
    //ajoute la classe active au bouton
    boutonModal.className += " tabber-active";
    
    //affiche le modal
    modalContent.style.display = "block";
    
    //ferme le modal lorsqu'on clique sur le bouton close
    boutonClose.addEventListener("click", function(){
      modalContent.style.display = "none";
      boutonModal.className = boutonModal.className.replace("tabber-active", "")
    });
    
    //ferme le modal lorsqu'on clique en dehors du modal
    window.addEventListener("click", function(e){
      if (e.target == modalContent) {
        modalContent.style.display = "none";
        boutonModal.className = boutonModal.className.replace("tabber-active", "")
      }
    });
  });
}

/*switch de contenu*/

function switchDiv(content){
  
  //sélectionne le bouton à l'intérieur de l'id buttonContainer
  var boutonSwitch = content.querySelector(".button");
  
  //exécute la fonction suivante à chaque clique sur le bouton
  boutonSwitch.addEventListener("click", function(){
    
    //sélectionne toutes les div avec l'id change
    var changeDiv = content.querySelectorAll("div#change");
    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++) {
      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;
      }
    }
  });
}

//s'exécute une fois au chargement de chaque page
(function(){
  
  //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 boutonTabber
    boutonTabber(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");
  
  //parcourt chaque div contenant un modal, rien si vide
  modalContainer.forEach(function(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"); 
  
  //parcourt chaque div contenant un bouton pour switch, rien si vide
  bcontainer.forEach(function(e){
    
    //exécute la fonction switchDiv
    switchDiv(e);
  });
})();

/* Pour les cookies */

(function () {
    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();
})();