MediaWiki:Common.js: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
Rolf (Diskussion | Beiträge) K |
Rolf (Diskussion | Beiträge) |
||
Zeile 116: | Zeile 116: | ||
// Einklappbare Infoboxen von Curilias | // Einklappbare Infoboxen von Curilias | ||
var | var HideContent = '[–]'; | ||
var | var ShowContent = '[+]'; | ||
function | function toggleContent(indexContainer) { | ||
var | var taContent = document.getElementById("taContent" + indexContainer); | ||
var | var toggleContentLink = document.getElementById("toggleContentLink" + indexContainer); | ||
if (! | if (!taContent || !toggleContentLink ) { return false; } | ||
if ( | if (toggleContentLink.firstChild.data == HideContent) { | ||
taContent.style.display = 'none'; | |||
} else if ( | } else if (toggleContentLink.firstChild.data == ShowContent) { | ||
taContent.style.display = 'block'; | |||
} | } | ||
if ( | if (toggleContentLink.firstChild.data == HideContent) { | ||
toggleContentLink.firstChild.data = ShowContent; | |||
} else { | } else { | ||
toggleContentLink.firstChild.data = HideContent; | |||
} | } | ||
} | } | ||
function | function addToggleContentLink() { | ||
var | var indexContainer = 0; | ||
for (var i = 0; | for (var i = 0; taContainer = document.getElementsByTagName("div")[i]; i++) { | ||
if ( | if (taContainer.className == "ta_container") { | ||
indexContainer++; | |||
// create linkt to toggle visibility | // create linkt to toggle visibility | ||
var | var toggleContentLink = document.createElement("a"); | ||
toggleContentLink.className = 'ta_toggle'; | |||
toggleContentLink.setAttribute('title', 'Ein-/Ausklappen'); | |||
toggleContentLink.setAttribute('id', 'toggleContentLink' + indexContainer); | |||
toggleContentLink.setAttribute('href', 'javascript:toggleContent(' + indexContainer + ');'); | |||
var | var toggleCaption = document.createTextNode(HideContent); | ||
toggleContentLink.appendChild(toggleCaption); | |||
taContainer.insertBefore(toggleContentLink, taContainer.firstChild); | |||
for (var j=0; | for (var j=0; taContent = taContainer.getElementsByTagName("div")[j]; j++) { | ||
if ( | if (taContent.className == "ta_content") { | ||
taContent.setAttribute('id', 'taContent' + indexContainer); | |||
} | |||
if (taContent.className == "ta_content_default_hidden") { | |||
taContent.setAttribute('id', 'taContent' + indexContainer); | |||
taContent.style.display = 'none'; | |||
toggleContentLink.firstChild.data = ShowContent; | |||
} | } | ||
} | } | ||
Zeile 164: | Zeile 169: | ||
} | } | ||
addOnloadHook( | addOnloadHook(addToggleContentLink); |
Version vom 23. Juli 2008, 17:57 Uhr
/* Jedes JavaScript hier wird für alle Benutzer für jede Seite geladen. */ //================================================================================ //*** Dynamic Navigation Bars // set up the words in your language var NavigationBarHide = 'Einklappen'; var NavigationBarShow = 'Ausklappen'; // set up max count of Navigation Bars on page, // if there are more, all will be hidden // NavigationBarShowDefault = 0; // all bars will be hidden // NavigationBarShowDefault = 1; // on pages with more than 1 bar all bars will be hidden if (typeof NavigationBarShowDefault == 'undefined' ) { var NavigationBarShowDefault = 1; } // adds show/hide-button to navigation bars addOnloadHook(function() { // shows and hides content and picture (if available) of navigation bars // Parameters: // indexNavigationBar: the index of navigation bar to be toggled function toggleNavigationBar(indexNavigationBar) { var NavToggle = document.getElementById("NavToggle" + indexNavigationBar); var NavFrame = document.getElementById("NavFrame" + indexNavigationBar); if (!NavFrame || !NavToggle) { return false; } // if shown now if (NavToggle.firstChild.data == NavigationBarHide) { for ( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if (NavChild.className == 'NavPic') { NavChild.style.display = 'none'; } if (NavChild.className == 'NavContent') { NavChild.style.display = 'none'; } if (NavChild.className == 'NavToggle') { NavChild.firstChild.data = NavigationBarShow; } } // if hidden now } else if (NavToggle.firstChild.data == NavigationBarShow) { for ( var NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if (NavChild.className == 'NavPic') { NavChild.style.display = 'block'; } if (NavChild.className == 'NavContent') { NavChild.style.display = 'block'; } if (NavChild.className == 'NavToggle') { NavChild.firstChild.data = NavigationBarHide; } } } } function toggleNavigationBarFunction(indexNavigationBar) { return function() { toggleNavigationBar(indexNavigationBar); return false; }; } var indexNavigationBar = 0; // iterate over all < div >-elements var divs = document.getElementsByTagName("div"); for (var i=0; i<divs.length; i++) { var NavFrame = divs[i]; // if found a navigation bar if (NavFrame.className == "NavFrame") { indexNavigationBar++; var NavToggle = document.createElement("a"); NavToggle.className = 'NavToggle'; NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar); NavToggle.setAttribute('href', '#'); NavToggle.onclick = toggleNavigationBarFunction(indexNavigationBar); var NavToggleText = document.createTextNode(NavigationBarHide); NavToggle.appendChild(NavToggleText); // add NavToggle-Button as first div-element // in < div class="NavFrame" > NavFrame.insertBefore( NavToggle, NavFrame.firstChild ); NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar); } } // if more Navigation Bars found than Default: hide all if (NavigationBarShowDefault < indexNavigationBar) { for( var i=1; i<=indexNavigationBar; i++ ) { toggleNavigationBar(i); } } }); //================================================================================ // Einklappbare Infoboxen von Curilias var HideContent = '[–]'; var ShowContent = '[+]'; function toggleContent(indexContainer) { var taContent = document.getElementById("taContent" + indexContainer); var toggleContentLink = document.getElementById("toggleContentLink" + indexContainer); if (!taContent || !toggleContentLink ) { return false; } if (toggleContentLink.firstChild.data == HideContent) { taContent.style.display = 'none'; } else if (toggleContentLink.firstChild.data == ShowContent) { taContent.style.display = 'block'; } if (toggleContentLink.firstChild.data == HideContent) { toggleContentLink.firstChild.data = ShowContent; } else { toggleContentLink.firstChild.data = HideContent; } } function addToggleContentLink() { var indexContainer = 0; for (var i = 0; taContainer = document.getElementsByTagName("div")[i]; i++) { if (taContainer.className == "ta_container") { indexContainer++; // create linkt to toggle visibility var toggleContentLink = document.createElement("a"); toggleContentLink.className = 'ta_toggle'; toggleContentLink.setAttribute('title', 'Ein-/Ausklappen'); toggleContentLink.setAttribute('id', 'toggleContentLink' + indexContainer); toggleContentLink.setAttribute('href', 'javascript:toggleContent(' + indexContainer + ');'); var toggleCaption = document.createTextNode(HideContent); toggleContentLink.appendChild(toggleCaption); taContainer.insertBefore(toggleContentLink, taContainer.firstChild); for (var j=0; taContent = taContainer.getElementsByTagName("div")[j]; j++) { if (taContent.className == "ta_content") { taContent.setAttribute('id', 'taContent' + indexContainer); } if (taContent.className == "ta_content_default_hidden") { taContent.setAttribute('id', 'taContent' + indexContainer); taContent.style.display = 'none'; toggleContentLink.firstChild.data = ShowContent; } } } } } addOnloadHook(addToggleContentLink);