MediaWiki:Common.js: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
Rolf (Diskussion | Beiträge) K |
Rolf (Diskussion | Beiträge) |
||
(Eine dazwischenliegende Version desselben Benutzers wird nicht angezeigt) | |||
Zeile 114: | Zeile 114: | ||
//================================================================================ | //================================================================================ | ||
// Einklappbare | // BEGINN: Einklappbare Blockelemente (<div>) von Curilias | ||
// Version 0.9 - 2008-07-24 | |||
var | var HideContent = '[–]'; | ||
var | var ShowContent = '[+]'; | ||
function | function toggleContent(indexContainer) { | ||
var | var taContent = document.getElementById('taContent' + indexContainer); | ||
var | var taContent_alternativ = document.getElementById('taContent_alternativ' + indexContainer); | ||
var toggleContentLink = document.getElementById('toggleContentLink' + indexContainer); | |||
if (! | if (!taContent || !toggleContentLink ) { return false; } | ||
if ( | if (toggleContentLink.firstChild.data == HideContent) { | ||
taContent.style.display = 'none'; | |||
} else if ( | if (taContent_alternativ != null) | ||
taContent_alternativ.style.display = 'block'; | |||
} else if (toggleContentLink.firstChild.data == ShowContent) { | |||
taContent.style.display = 'block'; | |||
if (taContent_alternativ != null) | |||
taContent_alternativ.style.display = 'none'; | |||
} | } | ||
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 | toggleContentLink.setAttribute('style', 'float:right;font-size:x-small;margin:2px;'); | ||
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; | |||
} | |||
if (taContent.className == 'ta_content_alternativ') { | |||
taContent.setAttribute('id', 'taContent_alternativ' + indexContainer); | |||
taContent.style.display = 'block'; | |||
} | } | ||
} | } | ||
Zeile 164: | Zeile 180: | ||
} | } | ||
addOnloadHook( | addOnloadHook(addToggleContentLink); | ||
// ENDE: Einklappbare Blockelemente (<div>) von Curilias | |||
//================================================================================ |
Aktuelle Version vom 24. Juli 2008, 11:05 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); } } }); //================================================================================ // BEGINN: Einklappbare Blockelemente (<div>) von Curilias // Version 0.9 - 2008-07-24 var HideContent = '[–]'; var ShowContent = '[+]'; function toggleContent(indexContainer) { var taContent = document.getElementById('taContent' + indexContainer); var taContent_alternativ = document.getElementById('taContent_alternativ' + indexContainer); var toggleContentLink = document.getElementById('toggleContentLink' + indexContainer); if (!taContent || !toggleContentLink ) { return false; } if (toggleContentLink.firstChild.data == HideContent) { taContent.style.display = 'none'; if (taContent_alternativ != null) taContent_alternativ.style.display = 'block'; } else if (toggleContentLink.firstChild.data == ShowContent) { taContent.style.display = 'block'; if (taContent_alternativ != null) taContent_alternativ.style.display = 'none'; } 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 + ');'); toggleContentLink.setAttribute('style', 'float:right;font-size:x-small;margin:2px;'); 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; } if (taContent.className == 'ta_content_alternativ') { taContent.setAttribute('id', 'taContent_alternativ' + indexContainer); taContent.style.display = 'block'; } } } } } addOnloadHook(addToggleContentLink); // ENDE: Einklappbare Blockelemente (<div>) von Curilias //================================================================================