MediaWiki:Common.js: Unterschied zwischen den Versionen

Aus HuskyWiki
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
Zeile 1: Zeile 1:
/* Jedes JavaScript hier wird für alle Benutzer für jede Seite geladen. */
/* Jedes JavaScript hier wird für alle Benutzer für jede Seite geladen. */


/* Any JavaScript here will be loaded for all users on every page load. */
// ============================================================
// BEGIN Enable multiple onload functions
// setup onload functions this way:
// aOnloadFunctions[aOnloadFunctions.length] = function_name; // without brackets!
if (!window.aOnloadFunctions) {
  var aOnloadFunctions = new Array();
}
window.onload = function() {
  if (window.aOnloadFunctions) {
    for (var _i=0; _i<aOnloadFunctions.length; _i++) {
      aOnloadFunctions[_i]();
    }
  }
}
// END Enable multiple onload functions
// ============================================================


// <syntax type="javascript">
// ============================================================
 
// BEGIN Dynamic Navigation Bars
    /**
// NEEDS Enable multiple onload functions
        Toggles the display of elements on a page  
        Author/contact: Austin Che http://openwetware.org/wiki/User:Austin_J._Che
// set up the words in your language
        See http://openwetware.org/wiki/OpenWetWare:Toggle for examples and documentation
var NavigationBarHide = 'Einklappen';
     */
var NavigationBarShow = 'Ausklappen';
 
// indexed array of toggler ids to array of associated toggle operations
// set up max count of Navigation Bars on page,
// each operation is a two element array, the first being the type, the second a class name or array of elements
// if there are more, all will be hidden
// operation types are strings like "_reset" or "" for the default toggle operation
// NavigationBarShowDefault = 0; // all bars will be hidden
var togglers = new Array();      
// NavigationBarShowDefault = 1; // on pages with more than 1 bar all bars will be hidden
var allClasses = new Object(); // associative map of class names to page elements
if (typeof NavigationBarShowDefault == 'undefined' ) {
 
     var NavigationBarShowDefault = 1;
function toggler(id)
}
{
     var toBeToggled = togglers[id];
// shows and hides content and picture (if available) of navigation bars
     if (!toBeToggled)
// Parameters:
         return;
//     indexNavigationBar: the index of navigation bar to be toggled
 
function toggleNavigationBar(indexNavigationBar)
     // if some element is in list more than once, it will be toggled multiple times
{
     for (var i = 0; i < toBeToggled.length; i++)
     var NavToggle = document.getElementById("NavToggle" + indexNavigationBar);
    {
     var NavFrame = document.getElementById("NavFrame" + indexNavigationBar);
        // get array of elements to operate on
        var toggles = toBeToggled[i][1];
     if (!NavFrame || !NavToggle) {
        if (typeof(toggles) == "string")
         return false;
        {
    }
             if (toggles.charAt(0) == '-')
             {
     // if shown now
                 // treat as an element ID, not as class
     if (NavToggle.firstChild.data == NavigationBarHide) {
                 toggles = document.getElementById(toggles.substring(1));
        for (
                if (toggles)
                var NavChild = NavFrame.firstChild;
                    toggles = new Array(toggles);
                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;
             }
             }
            else
                toggles = allClasses[toggles];
         }
         }
        if (!toggles || !toggles.length)
    }
            continue;
}
 
        var op = toBeToggled[i][0]; // what the operation will be
// adds show/hide-button to navigation bars
 
function createNavigationBarToggleButton()
         switch (op)
{
         {
    var indexNavigationBar = 0;
            case "_reset":
    // iterate over all < div >-elements
                for (var j in toggles)
    for(
                    toggles[j].style.display = toggles[j]._toggle_original_display;
            var i=0;
                break;
            NavFrame = document.getElementsByTagName("div")[i];  
             case "_show":
            i++
                for (var j in toggles)
         ) {
                    toggles[j].style.display = '';
         // if found a navigation bar
                break;
        if (NavFrame.className == "NavFrame") {
             case "_hide":
                for (var j in toggles)
            indexNavigationBar++;
                    toggles[j].style.display = 'none';
             var NavToggle = document.createElement("a");
                break;
            NavToggle.className = 'NavToggle';
             case "":
            NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);
             default:
             NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');
                 // Toggle
                 for (var j in toggles)
            var NavToggleText = document.createTextNode(NavigationBarHide);
                    toggles[j].style.display = ((toggles[j].style.display == 'none') ? '' : 'none');
            NavToggle.appendChild(NavToggleText);
                break;
            // 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) {
function createTogglerLink(toggler, id)
         for(
{
                var i=1;  
    var toggle = document.createElement("a");
                i<=indexNavigationBar;  
    toggle.className = 'toggler-link';
                i++
    toggle.setAttribute('id', 'toggler' + id);
         ) {
    toggle.setAttribute('href', 'javascript:toggler("' + id + '");');
             toggleNavigationBar(i);
    var child = toggler.firstChild;
    toggler.removeChild(child);
    toggle.appendChild(child);
    toggler.insertBefore(toggle, toggler.firstChild);
}
 
function toggleInit()
{
    var togglerElems = new Array();
    var toggleGroup = new Array();
 
     // initialize/clear any old information
    togglers = new Array();   
    allClasses = new Object();
       
    // make list of all document classes
     var elems = document.getElementsByTagName("*");
    var numelems = elems.length;
    for (var i = 0; i < elems.length; i++)
    {
         var elem = elems[i];
        if (!elem.className)
            continue;
 
        elem._toggle_original_display = elem.style.display;
        var togglerID = -1;
        var elemClasses = elem.className.split(' '); // get list of classes
        for (var j = 0; j < elemClasses.length; j++)
         {
            var elemClass = elemClasses[j];
            if (! allClasses[elemClass])
                allClasses[elemClass] = new Array();
            allClasses[elemClass].push(elem);
 
            // all the special classes begin with _toggle
            if (elemClass.substring(0, 7) != "_toggle")
                continue;
 
            if (elemClass == "_togglegroup")
                toggleGroup = new Array();
            else if (elemClass == "_toggle")
                toggleGroup.push(elem);
            else if (elemClass.substring(0, 12) == "_toggle_init")
            {
                // set initial value for display (ignore the original CSS set value)
                // understands _toggle_initshow and _toggle_inithide
                var disp = elemClass.substring(12);
                if (disp == "show")
                    elem.style.display = '';
                else if (disp == "hide")
                    elem.style.display = 'none';
                elem._toggle_original_display = disp;
            }
             else if (elemClass.substring(0, 8) == "_toggler")
            {
                if (togglerID == -1)
                {
                    togglerID = togglers.length;
                    togglers[togglerID] = new Array();
                    togglerElems[togglerID] = elem;
                }
 
                // all classes are of form _toggler_op-CLASS
                // figure out what class we're toggling
                // if none is specified, then we use the current toggle group
                var toBeToggled;
                var hyphen = elemClass.indexOf('-');
                if (hyphen != -1)
                    toBeToggled = elemClass.substring(hyphen+1);
                else
                {
                    toBeToggled = toggleGroup;
                    hyphen = elemClass.length;
                }
 
                var op = elemClass.substring(8, hyphen);
                togglers[togglerID].push(new Array(op, toBeToggled));
            }
         }
         }
     }
     }
 
    // add javascript links to all toggler elements
}
    for (var i = 0; i < togglerElems.length; i++)
        createTogglerLink(togglerElems[i], i);
aOnloadFunctions[aOnloadFunctions.length] = createNavigationBarToggleButton;
}
 
// END Dynamic Navigation Bars
addOnloadHook(toggleInit);
// ============================================================
 
// </syntax>

Version vom 11. Mai 2008, 10:43 Uhr

/* Jedes JavaScript hier wird für alle Benutzer für jede Seite geladen. */

 // ============================================================
 // BEGIN Enable multiple onload functions
 
 // setup onload functions this way:
 // aOnloadFunctions[aOnloadFunctions.length] = function_name; // without brackets!
 
 if (!window.aOnloadFunctions) {
   var aOnloadFunctions = new Array();
 }
 
 window.onload = function() {
   if (window.aOnloadFunctions) {
     for (var _i=0; _i<aOnloadFunctions.length; _i++) {
       aOnloadFunctions[_i]();
     }
   }
 }
 
 // END Enable multiple onload functions
 // ============================================================

 // ============================================================
 // BEGIN Dynamic Navigation Bars
 // NEEDS Enable multiple onload functions 
 
 // 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;
 }
 
 // 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;
            }
        }
    }
 }
 
 // adds show/hide-button to navigation bars
 function createNavigationBarToggleButton()
 {
    var indexNavigationBar = 0;
    // iterate over all < div >-elements
    for(
            var i=0; 
            NavFrame = document.getElementsByTagName("div")[i]; 
            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', 'javascript:toggleNavigationBar(' + 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);
        }
    }
 
 }
 
 aOnloadFunctions[aOnloadFunctions.length] = createNavigationBarToggleButton;
 
 // END Dynamic Navigation Bars
 // ============================================================