MediaWiki:Common.js

El Komunejo

(Malsamoj inter versioj)
Iri al: navigado, serĉi
E (alia versio)
E (nova provo)
Linio 8: Linio 8:
//
//
//============================================================
//============================================================
-
 
+
// BEGIN Dynamic Navigation Bars (experimantal)
-
 
+
-
/** Dynamic Navigation Bars (experimental) *************************************
+
-
  *
+
-
  *  Description: See [[Wikipedia:NavFrame]].
+
-
  *  Maintainers: UNMAINTAINED
+
-
  */
+
   
   
-
  // set up the words in your language
+
// set up the words in your language
-
  var NavigationBarHide = '[' + collapseCaption + ']';
+
var NavigationBarHide = '[ Kaŝi ]';
-
  var NavigationBarShow = '[' + expandCaption + ']';
+
var NavigationBarShow = '[ Montri ]';
   
   
-
  // shows and hides content and picture (if available) of navigation bars
+
  var NavigationBarShowDefault = 0;
-
  // 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 ( hasClass( NavChild, 'NavPic' ) ) {
+
-
                NavChild.style.display = 'none';
+
-
            }
+
-
            if ( hasClass( NavChild, 'NavContent') ) {
+
-
                NavChild.style.display = 'none';
+
-
            }
+
-
        }
+
-
    NavToggle.firstChild.data = NavigationBarShow;
+
-
+
-
    // if hidden now
+
-
    } else if (NavToggle.firstChild.data == NavigationBarShow) {
+
-
        for (
+
-
                var NavChild = NavFrame.firstChild;
+
-
                NavChild != null;
+
-
                NavChild = NavChild.nextSibling
+
-
            ) {
+
-
            if (hasClass(NavChild, 'NavPic')) {
+
-
                NavChild.style.display = 'block';
+
-
            }
+
-
            if (hasClass(NavChild, 'NavContent')) {
+
-
                NavChild.style.display = 'block';
+
-
            }
+
-
        }
+
-
    NavToggle.firstChild.data = NavigationBarHide;
+
-
    }
+
-
  }
+
-
+
-
  // adds show/hide-button to navigation bars
+
-
  function createNavigationBarToggleButton()
+
-
  {
+
-
    var indexNavigationBar = 0;
+
-
    // iterate over all < div >-elements
+
-
    var divs = document.getElementsByTagName("div");
+
-
    for(
+
-
            var i=0;
+
-
            NavFrame = divs[i];
+
-
            i++
+
-
        ) {
+
-
        // if found a navigation bar
+
-
        if (hasClass(NavFrame, "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);
+
-
            for (
+
-
                  var NavChild = NavFrame.firstChild;
+
-
                  NavChild != null;
+
-
                  NavChild = NavChild.nextSibling
+
-
                ) {
+
-
                if ( hasClass( NavChild, 'NavPic' ) || hasClass( NavChild, 'NavContent' ) ) {
+
-
                    if (NavChild.style.display == 'none') {
+
-
                        NavToggleText = document.createTextNode(NavigationBarShow);
+
-
                        break;
+
-
                    }
+
-
                }
+
-
            }
+
-
+
-
            NavToggle.appendChild(NavToggleText);
+
-
            // Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)
+
-
            for(
+
-
              var j=0;
+
-
              j < NavFrame.childNodes.length;
+
-
              j++
+
-
            ) {
+
-
              if (hasClass(NavFrame.childNodes[j], "NavHead")) {
+
-
                NavFrame.childNodes[j].appendChild(NavToggle);
+
-
              }
+
-
            }
+
-
            NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
+
-
        }
+
-
    }
+
-
  }
+
   
   
 +
// 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;
 +
  }
 +
 +
  // ajout par Dake - permet de créer un titre en lieu et place du "Dérouler" grâce
 +
  // à l'attribut "title" du tag.
 +
  var ShowText;
 +
 +
  if (NavFrame.title == undefined || NavFrame.title.length == 0 ) {
 +
    ShowText = NavigationBarShow;
 +
  } else {
 +
    ShowText = NavFrame.title;
 +
  }
 +
 +
  // 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 = ShowText;
 +
          }
 +
      }
 +
 +
  // if hidden now
 +
  } else if (NavToggle.firstChild.data == ShowText) {
 +
      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);
 +
      }
 +
  }
 +
}
   
   
addOnloadHook(createNavigationBarToggleButton);
addOnloadHook(createNavigationBarToggleButton);
Linio 123: Linio 125:
 +
 +
 +
/*  </nowiki> </pre>*/
/** WikiMiniAtlas *******************************************************
/** WikiMiniAtlas *******************************************************

Kiel registrite je 17:20, 15. Mar 2008

/* Ĉiu ajn JavaSkriptaĵo ĉi tie estos ŝarĝita por ĉiu uzanto sur ĉiu paĝo. 
*/
/* <pre> <nowiki> 
*/   
//============================================================
//
// Kaŝskatoloj
//
//============================================================
// BEGIN Dynamic Navigation Bars (experimantal)
 
 // set up the words in your language
 var NavigationBarHide = '[ Kaŝi ]';
 var NavigationBarShow = '[ Montri ]';
 
 var NavigationBarShowDefault = 0;
 
 // 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;
   }
 
   // ajout par Dake - permet de créer un titre en lieu et place du "Dérouler" grâce
   // à l'attribut "title" du tag.
   var ShowText;
 
   if (NavFrame.title == undefined || NavFrame.title.length == 0 ) {
    ShowText = NavigationBarShow;
   } else {
    ShowText = NavFrame.title;
   }
 
   // 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 = ShowText;
           }
       }
 
   // if hidden now
   } else if (NavToggle.firstChild.data == ShowText) {
       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);
       }
   }
}
 
addOnloadHook(createNavigationBarToggleButton);
 
 // END Dynamic Navigation Bars
 
 
 
 
 
/*  </nowiki> </pre>*/
 
/** WikiMiniAtlas *******************************************************
   *
   *  Priskribo: WikiMiniAtlas estas ŝprucanta alklakebla kaj tirebla mondmapo. 
   *             La skripto estigas ke ĉiuj viaj koordinataj ligiloj montras la WikiMiniAtlas-ŝprucbutonon. 
   *             La skripto mem estas lokita sur meta ĉar ĝi estas uzata de multaj projektoj. 
   *             Vidu [[Meta:WikiMiniAtlas]] por plia informo. 
   *  Kreita de : [[:en:User:Dschwen]]
   */
 
 document.write('<script type="text/javascript" src="' 
     + 'http://meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js' 
     + '&action=raw&ctype=text/javascript&smaxage=21600&maxage=86400"></script>');
 
/*  </nowiki> </pre>*/
Personaj iloj