User:SADIQUI/vector.js
Note: After publishing, you may have to bypass your browser's cache to see the changes.
- Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
- Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
- Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
- Opera: Press Ctrl-F5.
/* ajoute une classe à un element */
function addClass(elem,classe) {
elem.className += " "+classe;
}
/* enlève la premiere occurence du nom d'une classe d'un element */
function removeClass(elem,classe) {
var reg = new RegExp('(\\s|^)'+classe+'(\\s|$)');
elem.className=elem.className.replace(reg,' '); //ne replace que la premiere occurence (comme ça les hide imbriqués restent en hide ^^)
}
/* Cette fonction ajoute un "onclick" sur chaque titre, qui lancera un appel à toogleTitle() lors d'un clic sur ceux ci */
function ImplementToogleOnclick() {
for( var titleLevel = 1 ; titleLevel <= 6 ; titleLevel++) { //tous les h1, h2 ... h6
var titleList = document.getElementsByTagName('h' + titleLevel)
var nb = titleList.length
for( var a = 0 ; a < nb ; a++) {
titleList[a].setAttribute('onclick', "toogleTitle(this)");
}
}
//pour que ça ne se replie pas quand on clique sur un bouton modifier, on annule l'event au niveau du lien
var editLinkList = document.getElementsByClassName('editsection')
nb = editLinkList.length
for( a = 0 ; a < nb ; a++) {
editLinkList[a].setAttribute('onclick', "event.cancelBubble=true;");
}
}
$(ImplementToogleOnclick)
/* Cette fonction, quand invoquée, fait disparaitre ou réaparaitre le contenu placé sous un titre jusqu'au prochain titre de niveau egal ou supérieur
(= un h3 s'arrete au prochain h2 ou h3 mais continuera s'il rencontre un h4 ou h5) */
function toogleTitle(p_this) {
var titre_niveau = p_this.nodeName.substring(1,2) //le x de hx (1 de h1, etc.)
//construction de l'expression reguliere permettant le trouver le prochain titre de niveau égal ou supérieur
var stopMatch = "(h1"
for(var niveau = 2 ; niveau <= titre_niveau ; niveau++) {
stopMatch += "|h" + niveau
}
stopMatch += ")"
regex_stopMatch = new RegExp(stopMatch, "i" )
var nextSiblingNode = p_this.nextSibling
if( p_this.className != "neko_toogle_cache" ) { // il faut replier
p_this.className = "neko_toogle_cache" //on ajoute une classe au titre pour savoir s'il est en mode replié
while( nextSiblingNode ) {
if( nextSiblingNode.nodeName.match(regex_stopMatch) ) break; //on a atteint le titre "bloquant" suivant = stop
if( nextSiblingNode.style && nextSiblingNode.nodeName != 'SCRIPT' ) addClass(nextSiblingNode, "hidden") //ne pas affecter les nodes texte ni script
nextSiblingNode = nextSiblingNode.nextSibling //on passe au voisin suivant
}
} else { //il faut déplier
p_this.className = ""
while( nextSiblingNode ) {
if( nextSiblingNode.nodeName.match(regex_stopMatch) ) break;
if( nextSiblingNode.style && nextSiblingNode.nodeName != 'SCRIPT' ) removeClass(nextSiblingNode, "hidden")
nextSiblingNode = nextSiblingNode.nextSibling
}
}
}