39,229 bytes removed ,  21:14, 3 May 2012
Line 1: Line 1:  
/* Any JavaScript here will be loaded for all users on every page load. */
 
/* Any JavaScript here will be loaded for all users on every page load. */
  −
  −
//
  −
// Insert a personalized Texttemplate into the Special:Upload edit box.
  −
//
  −
function delayedUpdateSpecialUpload(){
  −
var editbox = document.getElementById('wpUploadDescription');
  −
  −
if (location.href == "http://wikivet.net/index.php/Special:Upload"){
  −
  −
editbox.value = "{"+"{Information\n"
  −
                + "|Description=\n"
  −
                + "|Source=\n"
  −
                + "|Date=\n"
  −
                + "|Author=\n"
  −
                + "|Permission=See below\n"
  −
                + "|Other_versions=\n"
  −
                + "}"+"}\n\n";
  −
}
  −
  −
if (location.href == "http://wikivet.net/index.php?title=Special:Upload&uselang=own"){
  −
  −
editbox.value  = "{"+"{Information\n"
  −
              + "|Description=\n"
  −
              + "|Source=Own Work\n"
  −
              + "|Date=" + window.location.pathname + "\n"
  −
              + "|Author=" + "\[\[User:" + wgUserName + "|" + wgUserName + "\]\]" + "\n"
  −
              + "|Permission=See below\n"
  −
              + "}"+"}\n\n";
  −
}
  −
  −
if (window.location.pathname == "/index.php"){
  −
  −
editbox.value  = "{"+"{Information\n"
  −
              + "|Description=\n"
  −
              + "|Source=\n"
  −
              + "|Date=\n"
  −
              + "|Author=\n"
  −
              + "|Permission=See below\n"
  −
              + "}"+"}\n\n";
  −
}
  −
}
  −
addOnloadHook(delayedUpdateSpecialUpload);
  −
  −
  −
function includePage( name )
  −
{
  −
document.write('<script type="text/javascript" src="' + wgScript + '?title='
  −
  + name
  −
  + '&action=raw&ctype=text/javascript"><\/script>'
  −
);
  −
}
  −
/* End of includePage */
  −
  −
/** Collapsible tables *********************************************************
  −
*
  −
*  Description: Allows tables to be collapsed, showing only the header. See
  −
*              http://www.mediawiki.org/wiki/Manual:Collapsible_tables.
  −
*  Maintainers: [[**MAINTAINERS**]]
  −
*/
  −
var autoCollapse = 2;
  −
var collapseCaption = 'hide';
  −
var expandCaption = 'show';
  −
  −
function collapseTable( tableIndex ) {
  −
var Button = document.getElementById( 'collapseButton' + tableIndex );
  −
var Table = document.getElementById( 'collapsibleTable' + tableIndex );
  −
  −
if ( !Table || !Button ) {
  −
return false;
  −
}
  −
  −
var Rows = Table.rows;
  −
  −
if ( Button.firstChild.data == collapseCaption ) {
  −
for ( var i = 1; i < Rows.length; i++ ) {
  −
Rows[i].style.display = 'none';
  −
}
  −
Button.firstChild.data = expandCaption;
  −
} else {
  −
for ( var i = 1; i < Rows.length; i++ ) {
  −
Rows[i].style.display = Rows[0].style.display;
  −
}
  −
Button.firstChild.data = collapseCaption;
  −
}
  −
}
  −
  −
function createCollapseButtons() {
  −
var tableIndex = 0;
  −
var NavigationBoxes = new Object();
  −
var Tables = document.getElementsByTagName( 'table' );
  −
  −
for ( var i = 0; i < Tables.length; i++ ) {
  −
if ( hasClass( Tables[i], 'collapsible' ) ) {
  −
/* only add button and increment count if there is a header row to work with */
  −
var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
  −
if( !HeaderRow ) continue;
  −
var Header = HeaderRow.getElementsByTagName( 'th' )[0];
  −
if( !Header ) continue;
  −
  −
NavigationBoxes[tableIndex] = Tables[i];
  −
Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
  −
  −
var Button    = document.createElement( 'span' );
  −
var ButtonLink = document.createElement( 'a' );
  −
var ButtonText = document.createTextNode( collapseCaption );
  −
  −
Button.className = 'collapseButton'; // Styles are declared in MediaWiki:Common.css
  −
  −
ButtonLink.style.color = Header.style.color;
  −
ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
  −
ButtonLink.setAttribute( 'href', "javascript:collapseTable(" + tableIndex + ");" );
  −
ButtonLink.appendChild( ButtonText );
  −
  −
Button.appendChild( document.createTextNode( '[' ) );
  −
Button.appendChild( ButtonLink );
  −
Button.appendChild( document.createTextNode( ']' ) );
  −
  −
Header.insertBefore( Button, Header.childNodes[0] );
  −
tableIndex++;
  −
}
  −
}
  −
  −
for ( var i = 0;  i < tableIndex; i++ ) {
  −
if ( hasClass( NavigationBoxes[i], 'collapsed' ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], 'autocollapse' ) ) ) {
  −
collapseTable( i );
  −
}
  −
}
  −
}
  −
  −
addOnloadHook( createCollapseButtons );
  −
  −
/** Test if an element has a certain class **************************************
  −
*
  −
* Description: Uses regular expressions and caching for better performance.
  −
* Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]]
  −
*/
  −
  −
var hasClass = (function() {
  −
var reCache = {};
  −
return function( element, className ) {
  −
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);
  −
};
  −
})();
  −
  −
  −
/** Dynamic Navigation Bars (experimental) *************************************
  −
  *
  −
  *  Description: See [[Wikipedia:NavFrame]].
  −
  *  Maintainers: UNMAINTAINED
  −
  */
  −
  −
  // set up the words in your language
  −
  var NavigationBarHide = '[' + collapseCaption + ']';
  −
  var NavigationBarShow = '[' + expandCaption + ']';
  −
 
  −
  // 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
  −
  var NavigationBarShowDefault = autoCollapse;
  −
 
  −
 
  −
  // 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 ( 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);
  −
            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);
  −
        }
  −
    }
  −
    // if more Navigation Bars found than Default: hide all
  −
    if (NavigationBarShowDefault < indexNavigationBar) {
  −
        for(
  −
                var i=1;
  −
                i<=indexNavigationBar;
  −
                i++
  −
        ) {
  −
            toggleNavigationBar(i);
  −
        }
  −
    }
  −
 
  −
  }
  −
  addOnloadHook( createNavigationBarToggleButton );
  −
  −
  −
  −
  −
  −
  −
//<pre>
  −
//Version: 3.1
  −
//============================================================
  −
// en: ADD SOME EXTRA BUTTONS TO THE EDITPANEL
  −
// de: FÜGE NEUE BUTTON IN DIE WERKZEUGLEISTE
  −
//============================================================
  −
// Vorschläge für neue Buttons werden gerne entgegengenommen
  −
// Die Reihenfolge und Anzahl der Buttons ist über die (alphabetische) Variable XEBOrder wählbar.
  −
  −
//================================
  −
//Control Variables
  −
//
  −
//rmEditButtons - Removes standard toolbar buttons
  −
//XEBOrder - The order in which the buttons are displayed
  −
  −
importStylesheetURI( 'Mediawiki:Common.css' );
  −
  −
if(typeof XEBPopups== 'undefined')XEBPopups=true;
  −
if(typeof XEBHideDelay== 'undefined')XEBHideDelay=0.5; //Time before the popup disappears after the mouse moves out
  −
if(typeof XEBExtendEditSummary == 'undefined')XEBExtendEditSummary=true; // Is the edit summary extended after a popup
  −
  −
//fills the variable mwCustomEditButtons (s. function in /wikibits.js), with buttons for the Toolbar 
  −
function addCustomButton(imageFile, speedTip, tagOpen, tagClose, sampleText){
  −
mwCustomEditButtons.push({
  −
  "imageFile": imageFile,
  −
  "speedTip": speedTip,
  −
  "tagOpen": tagOpen,
  −
  "tagClose": tagClose,
  −
  "sampleText": sampleText});
  −
}
  −
  −
if (typeof usersignature == 'undefined') var usersignature = '-- \~\~\~\~';
  −
  −
var Isrc='http://upload.wikimedia.org/wikipedia/commons/';
  −
  −
// English Wikipedia creates 11 extra buttons which are stored in mwCustomEditButtons
  −
//  rather than mwEditButtons. However, there is no guarantee it will always be 11
  −
//  so we count them here.
  −
var enExtraButtons=mwCustomEditButtons.length;
  −
  −
  −
var BDict={
  −
'A':['e/e9/Button_headline2.png','Secondary headline','\n===','===','Secondary headline'],
  −
'B':['1/13/Button_enter.png','Line break','<br />','',''],
  −
'C':['5/5f/Button_center.png','Center','<div style="text-align: center;">\n','\n<\/div>','Centred text'],
  −
'D':['e/ea/Button_align_left.png','Left-Align','<div style="text-align: left; direction: ltr; margin-left: 1em;">\n','\n<\/div>','Left-aligned text'],
  −
'D1':['a/a5/Button_align_right.png','Right-Align','<div style="text-align: right; direction: ltr; margin-left: 1em;">\n','\n<\/div>','Right-aligned text'],
  −
'E':['0/04/Button_array.png','Table','\n{| class="wikitable" \n|- \n| 1 || 2\n|- \n| 3 || 4','\n|}\n',''],
  −
'F':['1/1e/Button_font_color.png','Insert coloured text','<span style="color: ','">Coloured text<\/span>','ColourName'],
  −
'FS':['1/1b/Button_miss_signature.png','Unsigned post','{{subst:unsigned|','|date}}','user name or IP'],
  −
'G':['9/9e/Btn_toolbar_gallery.png','Picture gallery',"\n<gallery>\nImage:","|[[M63]]\nImage:Mona Lisa.jpg|[[Mona Lisa]]\nImage:Truite arc-en-ciel.jpg|Eine [[Forelle ]]\n<\/gallery>",'M63.jpg'],
  −
'H':['7/74/Button_comment.png','Comment',"<!--","-->",'Comment'],
  −
'I1':['6/6a/Button_sup_letter.png','Superscript','<sup>','<\/sup>','Superscript text'],
  −
'I2':['a/aa/Button_sub_letter.png','Subscript','<sub>','<\/sub>','Subscript text'],
  −
'J1':['5/58/Button_small.png','Small','<small>','<\/small>','Small Text'],
  −
'J2':['5/56/Button_big.png','Big text','<big>','<\/big>','Big text'],
  −
'K':['b/b4/Button_category03.png','Category',"[[Category:","]]",'Category name'],
  −
'L':['8/8e/Button_shifting.png','Insert tab(s)',':','',':'],
  −
'M':['f/fd/Button_blockquote.png','Insert block of quoted text','<blockquote style="border: 1px solid blue; padding: 2em;">\n','\n<\/blockquote>','Block quote'],
  −
'N':['4/4b/Button_nbsp.png','nonbreaking space','&nbsp;','',''],
  −
'O':['2/23/Button_code.png','Insert code','<code>','<\/code>','Code'],
  −
'P':['3/3c/Button_pre.png','Pre formatted Text','<pre>','<\/pre>','Pre formatted text'],
  −
'P1':['9/93/Button_sub_link.png','Insert link to sub-page','[[','/Sub_Page]]','Page'],
  −
'Q':['d/d3/Button_definition_list.png','Insert definition list','\n; ','\n: Item 1\n: Item 2','Definition'],
  −
'R':['7/79/Button_reflink.png','Insert a reference','<ref>','<\/ref>','Insert reference material'],
  −
'R1':['7/79/Button_reflink.png','Start a reference','<ref name="','','Reference name'],
  −
'R2':['9/99/Button_reflink_advanced_2.png','Insert reference material','">','</ref>','Reference material'],
  −
'R3':['1/1a/Button_reflink_advanced_3.png','No reference material','','"/>',''],
  −
'R4':['9/9a/Button_references.png','Reference footer',"\n==Notes==\n<!--See http://en.wikipedia.org/wiki/Wikipedia:Footnotes for an explanation of how to generate footnotes using the <ref(erences/)> tags-->\n<div class=\'references-small\'>\n<references/>\n</div>",'',''],
  −
'S':['c/c9/Button_strike.png','Strikeout','<s>','<\/s>','Struck out text'],
  −
'T':['e/eb/Button_plantilla.png','Template','{{','}}','Template name'],
  −
'TS':['a/a4/TableStart.png','Start a table','{|','',''],
  −
'TC':['7/71/TableCell.png','Table cell','|','',''],
  −
'TE':['0/06/TableEnd.png','End a table','','|}',''],
  −
'TR':['4/4c/TableRow.png','Start a table row','|-','',''],
  −
'T1':['3/30/Tt_icon.png','Teletype text','<tt>','<\/tt>','Teletype Text'],
  −
'TL':['3/37/Button_tl_template.png','Template link',"{{subst:"+"tl|",'}}','Template name'],
  −
'U':['f/fd/Button_underline.png','Underlined',"<u>","<\/u>",'Underlined text'],
  −
'V':['c/c8/Button_redirect.png','Redirect',"#REDIRECT [[","]]",'Article Name'],
  −
'W':['8/88/Btn_toolbar_enum.png','Numbering',"\n# ","\n# Element 2\n# Element 3",'Element 1'],
  −
'X':['1/11/Btn_toolbar_liste.png','List',"\n* ","\n* Element B\n* Element C",'Element A'],
  −
'Y1':['c/ce/Button_no_include.png','No Include',"<noinclude>","<\/noinclude>",'Text'],
  −
'Y2':['7/79/Button_include.png','Include only',"<includeonly>","<\/includeonly>",'Text'],
  −
'Z':['3/35/Button_substitute.png','Substitute',"{{subst:","}}",'Template'],
  −
'AI':['1/1c/Button_advanced_image.png','Advanaced Image',"[[Image:","|thumb|right|px|Caption]]",'FileName.jpg'],
  −
'GEO':['b/b8/Button_Globe.png','Geo location',"","",""],
  −
'TALK':['4/49/Button_talk.png','Add talk template',"","",""]
  −
};
  −
  −
var XEBOrder2=[];
  −
  −
  −
  −
  −
addOnloadHook(initButtons);
  −
if(!wgIsArticle)// only if edit
  −
{
  −
  −
if(XEBPopups)hookEvent("load", extendButtons);
  −
}
  −
  −
function initButtons(){
  −
  −
var bc,d;
  −
  −
if (typeof XEBOrder!='string') // can be modified
  −
XEBOrder2="A,D,C,D1,F,U,J1,E,G,Q,W,X,K,L,H,O,R,T".split(",");
  −
else if (XEBOrder.toLowerCase()=='all')
  −
for (b in BDict) XEBOrder2.push(b);
  −
else XEBOrder2=XEBOrder.toUpperCase().split(",");
  −
  −
for (b in BDict) BDict[b][0] = Isrc+BDict[b][0]; // // Add the start of the URL (Isrc) to the XEB buttons
  −
// If the user has defined any buttons then add them into the available button lists
  −
  −
if (typeof myButtons=='object')
  −
  for (b in myButtons) BDict[b] = myButtons[b]; // custom user buttons
  −
// Add the media wiki standard buttons into the available buttons
  −
  −
for (b in mwEditButtons) { // add standard buttons for full XEB order changing
  −
  −
// BDict[b]=[];
  −
BDict[b]=[mwEditButtons[b].imageFile,mwEditButtons[b].speedTip,mwEditButtons[b].tagOpen,mwEditButtons[b].tagClose,mwEditButtons[b].sampleText];
  −
  −
// for (d in mwEditButtons[b]) BDict[b].push(mwEditButtons[b][d]);
  −
}
  −
  −
// Build the new buttons
  −
  −
for (i=0;i<XEBOrder2.length;i++) {
  −
bc = BDict[XEBOrder2[i]];
  −
  −
//Check if bc is an object
  −
// - protects if user specified a non-existant buttons
  −
// - IE causes a javascript error when viewing a page
  −
if(typeof bc=='object')
  −
{
  −
  −
//Call addCustomButton in wikibits
  −
addCustomButton(bc[0],bc[1],bc[2],bc[3],bc[4]);
  −
}
  −
}
  −
  −
// Remove the default buttons (if requested by the user)
  −
eraseButtons();
  −
}
  −
  −
  −
/** en: Removes arbitrary standard buttons from the toolbar
  −
* @author: [[:de:User:Olliminatore]]
  −
* @version: 0.1 (01.10.2006) **/
  −
  −
function eraseButtons(){
  −
  −
//Remove the buttons the user doesn't want
  −
  −
if(typeof rmEditButtons!='object') return;
  −
  −
if (typeof rmEditButtons[0] == 'string' && rmEditButtons[0].toLowerCase() == 'all')
  −
{
  −
mwEditButtons=[];
  −
for(i=0;i<enExtraButtons;i++){mwCustomEditButtons.shift();}
  −
}
  −
//Sort the user's requests so we remove the button with the highest index first
  −
//- This ensures we remove the buttons the user expects whatever order he requested the buttons in
  −
rmEditButtons.sort(sortit);
  −
  −
//Remove individual buttons the user doesn't want
  −
  −
for(i=0;i<rmEditButtons.length;i++){
  −
var n=rmEditButtons[i];
  −
//Standard Wikimedia buttons
  −
if(n>=0 && n<mwEditButtons.length){
  −
if(n<mwEditButtons.length){
  −
var x = -1;
  −
while((++x)<mwEditButtons.length)
  −
if(x>=n)
  −
mwEditButtons[x] = mwEditButtons[x+1];
  −
}
  −
mwEditButtons.pop();
  −
}
  −
//Extra buttons in English Wikipedia
  −
n=n-mwEditButtons.length;
  −
if(n>0 && n<mwCustomEditButtons.length){
  −
if(n<mwCustomEditButtons.length){
  −
var x = -1;
  −
while((++x)<mwCustomEditButtons.length)
  −
if(x>=n)
  −
mwCustomEditButtons[x] = mwCustomEditButtons[x+1];
  −
}
  −
mwCustomEditButtons.pop();
  −
}
  −
}
  −
};
  −
  −
//Function:
  −
// sortit
  −
//Purpose:
  −
// Used to sort the rmEditButtons array into descending order
  −
function sortit(a,b){
  −
return(b-a)
  −
}
  −
  −
  −
//Function:
  −
//Purpose:
  −
// Adds extended onclick-function to some buttons
  −
function extendButtons(){
  −
  −
if(!(allEditButtons = document.getElementById('toolbar'))) return false;
  −
if(typeof editform != 'undefined')
  −
if(!(window.editform = document.forms['editform'])) return false;
  −
  −
//  table
  −
extendAButton(Isrc+"0/04/Button_array.png",XEBPopupTable)
  −
extendAButton(Isrc+"7/79/Button_reflink.png",XEBPopupRef)
  −
extendAButton(Isrc+"b/b8/Button_Globe.png",XEBPopupGeoLink)
  −
extendAButton(Isrc+"4/49/Button_talk.png",XEBPopupTalk)
  −
extendAButton(Isrc+"1/1c/Button_advanced_image.png",XEBPopupImage)
  −
//extendAButton(Isrc+"6/6a/Button_sup_letter.png",XEBPopupFormattedText)
  −
  −
// redirect -##IE doesn't like this line. Object doesn't support this propert<link rel="stylesheet" type="text/css" href="http://en.wikipedia.org/w/index.php?title=User:MarkS/XEB/live.css&action=raw&ctype=text/css&dontcountme=s">y or method
  −
//c=XEBOrder2.getIndex('V');
  −
  −
// if(c != -1)
  −
// allEditButtons[bu_len+c].onclick=function(){
  −
// var a='#REDIRECT \[\['+prompt("Which page do you want to redirect to\?")+'\]\]';
  −
// document.editform.elements['wpTextbox1'].value=a;
  −
// document.editform.elements['wpSummary'].value=a;
  −
// document.editform.elements['wpWatchthis'].checked=false
  −
//  };
  −
};
  −
  −
function extendAButton(url,newfunc)
  −
{
  −
if(!(allEditButtons = document.getElementById('toolbar'))) return false;
  −
if(typeof editform != 'undefined')
  −
if(!(window.editform = document.forms['editform'])) return false;
  −
allEditButtons = allEditButtons.getElementsByTagName('img');
  −
for(i=0;i<allEditButtons.length;i++)
  −
{
  −
if(allEditButtons[i].src==url)
  −
{
  −
allEditButtons[i].onclick=newfunc;
  −
}
  −
}
  −
}
  −
  −
//==========================================================================================================
  −
// General purpose popup code
  −
//==========================================================================================================
  −
  −
function getXEBPopupDiv(name)
  −
{
  −
XEBMainDiv= document.getElementById("XEB");
  −
if(XEBMainDiv==null){
  −
XEBMainDiv=document.createElement("div");
  −
document.body.appendChild(XEBMainDiv);
  −
XEBMainDiv.id="XEB";
  −
}
  −
  −
me= document.getElementById("XEBPopup" & name);
  −
if(!(me==null))return me;
  −
me=document.createElement("div");
  −
XEBMainDiv.appendChild(me);
  −
  −
me.id="XEBPopup";
  −
me.style.position='absolute';
  −
me.display='none';
  −
me.visibility='hidden';
  −
me.onmouseout=CheckHideXEBPopup;
  −
me.onmouseover=cancelHidePopup;
  −
return me;
  −
}
  −
  −
//Function:
  −
// CheckHideXEBPopup
  −
//Purpose:
  −
// Looks at the cursor position and if it has moved outside the popup it will close the popup
  −
//Called:
  −
// When the onMouseEvent is fired on the popup
  −
  −
function CheckHideXEBPopup(e){
  −
m= document.getElementById("XEBmnu");
  −
if(is_gecko)
  −
{
  −
ph=m.offsetHeight;
  −
var x=e.clientX + window.scrollX;
  −
var y=e.clientY + window.scrollY;;
  −
s=window.getComputedStyle(m,"");
  −
ph=s.height;
  −
ph=Number(ph.substring(0,ph.length-2));
  −
}
  −
else
  −
{
  −
var x=event.clientX+ document.documentElement.scrollLeft + document.body.scrollLeft;
  −
var y=event.clientY+ document.documentElement.scrollTop + document.body.scrollTop;
  −
ph=m.offsetHeight;
  −
}
  −
pl=curPopup.x;
  −
pt=curPopup.y;
  −
pw=m.style.width;
  −
pw=Number(pw.substring(0,pw.length-2));
  −
  −
if(x>(pl+2)&&x<(pl+pw-5)&&y>(pt+2)&&y<(pt+ph-5))return;
  −
curPopup.hideTimeout=setTimeout('hideXEBPopup()',XEBHideDelay*1000);
  −
}
  −
  −
function cancelHidePopup()
  −
{
  −
clearTimeout(curPopup.hideTimeout)
  −
}
  −
  −
function hideXEBPopup(){
  −
XEBMainDiv= document.getElementById("XEB");
  −
m= document.getElementById("XEBPopup");
  −
XEBMainDiv.removeChild(m);
  −
}
  −
  −
function XEBstartDrag(e)
  −
{
  −
m=new GetPos(e||event);
  −
curPopup.startDrag.mouse=m;
  −
curPopup.startDrag.floatpopup.y=parseInt(curPopup.div.style.top);
  −
curPopup.startDrag.floatpopup.x=parseInt(curPopup.div.style.left);
  −
curPopup.dragging=true;
  −
}
  −
  −
function XEBstopDrag(e)
  −
{
  −
if(curPopup.dragging==false)return;
  −
curPopup.dragging=false;
  −
}
  −
  −
function XEBDrag(e)
  −
{
  −
if(curPopup.dragging==false)return;
  −
  −
m=new GetPos(e||event);
  −
x=parseInt(curPopup.startDrag.floatpopup.x+(m.x-curPopup.startDrag.mouse.x));
  −
y=parseInt(curPopup.startDrag.floatpopup.y+(m.y-curPopup.startDrag.mouse.y));
  −
  −
curPopup.div.style.top=y+"px";
  −
curPopup.div.style.left=x+"px";
  −
  −
curPopup.x=x;
  −
curPopup.y=y;
  −
}
  −
  −
//=============================================================================
  −
// Popup: Table
  −
//=============================================================================
  −
  −
function XEBPopup(name,x,y)
  −
{
  −
// Make sure the popup can appear on the screen
  −
  −
this.IESelectedRange=XEBgetIESelectedRange();
  −
  −
winW=(is_gecko)?window.innerWidth:document.body.offsetWidth;
  −
if((winW-this.width)<x)x=(winW-this.width);
  −
  −
this.div=getXEBPopupDiv(name);
  −
this.div.style.zIndex=2000;
  −
this.div.display="inline";
  −
this.div.visibility="visible";
  −
this.div.style.top=y + "px";
  −
this.x=x;
  −
this.y=y;
  −
this.name=name;
  −
  −
this.startDrag=new Object;
  −
this.startDrag.floatpopup=new Object;
  −
}
  −
  −
function setInnerHTML(text)
  −
{
  −
winW=(is_gecko)?window.innerWidth:document.body.offsetWidth;
  −
if((winW-this.width)<this.x)this.x=(winW-this.width);
  −
this.div.style.left=this.x+ "px";
  −
  −
mt="<div id='XEBmnu' style='width:" + this.width + "px' >";
  −
mt+='<div id="XEBmnuTitle" class="XEBPopupTitle" onmousedown="XEBstartDrag(event)" onmouseup="XEBstopDrag(event)" onmousemove="XEBDrag(event)">Title</div>'
  −
mt+=text;
  −
mt+="</div>";
  −
this.div.innerHTML=mt;
  −
//Turn off autocomplete. If the mouse moves over the autocomplete popup then x,y in CheckHidePopup is relative to the
  −
// autocomplete popup and our popup is hidden
  −
var InTexts = this.div.getElementsByTagName('input');
  −
for (var i = 0; i < InTexts.length; i++) {
  −
        var theInput = InTexts[i];
  −
if (theInput.type == 'text'){theInput.setAttribute('autocomplete','off');}
  −
}
  −
//Add rollover features to menu items. Doing it here means we don't have to do it for each menu
  −
x=XEBgetElementsByClassName(this.div,'XEBMnuItm','span');
  −
for (var i = 0; i < x.length; i++) {
  −
        var theItm = x[i];
  −
theItm.onmouseout=XEBMenuMouseOut;
  −
theItm.onmouseover=XEBMenuMouseOver;
  −
}
  −
  −
this.div.style.borderWidth='thin';
  −
this.div.style.borderStyle='solid';
  −
this.div.style.backgroundColor='#D0D0D0';
  −
}
  −
XEBPopup.prototype.width=250;
  −
XEBPopup.prototype.dragging=false;
  −
XEBPopup.prototype.setInnerHTML=setInnerHTML;
  −
  −
var curPopup;
  −
  −
function GetPos(e)
  −
{
  −
this.x=e.clientX-10+ document.documentElement.scrollLeft + document.body.scrollLeft;
  −
this.y=e.clientY-10+ document.documentElement.scrollTop + document.body.scrollTop;
  −
}
  −
  −
function XEBPopupTable(e){
  −
m=new GetPos(e||event);
  −
  −
curPopup=new XEBPopup("table",m.x,m.y);
  −
  −
mt='<p>Enter the table parameters below: <\/p>'
  −
+'<form name="XEBPopupTableForm">'
  −
+'Table caption: <input type="checkbox" name="inputCaption"><p\/>'
  −
+'Table alignment: center<input type="checkbox" name="inputAlign"><p\/>'
  −
+'Table headline: colored<input type="checkbox" name="inputHead"><p\/>'
  −
+'Number of rows: <input type="text" name="inputRow" value="3" size="2"><p\/>'
  −
+'Number of columns: <input type="text" name="inputCol" value="3" size="2"><p\/>'
  −
//+'Alternating grey lines: <input type="checkbox" name="inputLine" checked="1" ><p\/>'
  −
+'Item column: <input type="checkbox" name="inputItems" ><p\/>'
  −
+'Sortable: <input type="checkbox" name="inputSort" ><p\/>'
  −
+'<\/form>'
  −
+'<i>The default table allows for fields and values only.<\/i><p\/>'
  −
+'Check "Item column" to allow for the table to have fields, items, and values.<\/i><p\/>'
  −
+'<p><button onClick="javascript:insertTableCode()">Insert</button>'
  −
+'<button onClick="hideXEBPopup()">Cancel</button>'
  −
  −
curPopup.setInnerHTML(mt);
  −
  −
return true;
  −
}
  −
  −
function insertTableCode(){
  −
f=document.XEBPopupTableForm;
  −
var caption = (f.inputCaption.checked)?"|+ TABLE CAPTION \n":"";
  −
var exhead = (f.inputHead.checked)?'|- style="background: #DDFFDD;"\n':"";
  −
var nbRow = parseInt(f.inputRow.value);
  −
var nbCol = parseInt(f.inputCol.value);
  −
var exfield = f.inputItems.checked;
  −
var align = (f.inputAlign.checked)?'align="center"':"";
  −
  −
//generateTable(caption, exhead, nbCol, nbRow, exfield, align);
  −
  −
var code = "\n";
  −
code += '{| {{prettytable}} ' + align + ' '; // en: class="wikitable"
  −
code+=(f.inputSort.checked)?'class="sortable" \n':'\n';
  −
code += caption + exhead;
  −
if (exfield) code += '!\n';
  −
for (i=1;i<nbCol+1;i++) code += '! FELD ' + i + '\n';
  −
var items = 0;
  −
for (var j=0;j<nbRow;j++){
  −
if (exfield) {
  −
items++;
  −
code += '|-\n! style="background: #FFDDDD;"|ITEM ' + items + '\n';
  −
} else code += '|-\n';
  −
for (i=0;i<nbCol;i++) code += '| Element\n';
  −
}
  −
code += '|}\n';
  −
hideXEBPopup();
  −
insertTags('','', code);
  −
extendSummary('table');
  −
  −
return false;
  −
  −
  −
// Get the text currently selected by user in the textAra
  −
// This code is based on part of the insertTags function in wikibits.js
  −
  −
function XEBGetSelectedText()
  −
{
  −
var txtarea;
  −
if (document.editform) {
  −
txtarea = document.editform.wpTextbox1;
  −
} else {
  −
// some alternate form? take the first one we can find
  −
var areas = document.getElementsByTagName('textarea');
  −
  −
txtarea = areas[0];
  −
}
  −
// IE & Opera
  −
if (document.selection  && !is_gecko)
  −
{
  −
var theSelection = document.selection.createRange().text;
  −
if (!theSelection) theSelection='';
  −
}
  −
// Mozilla
  −
else if(txtarea.selectionStart || txtarea.selectionStart == '0') {
  −
var replaced = false;
  −
var startPos = txtarea.selectionStart;
  −
var endPos = txtarea.selectionEnd;
  −
var theSelection = (txtarea.value).substring(startPos, endPos);
  −
if (!theSelection) theSelection='';
  −
}
  −
return theSelection;
  −
}
  −
  −
//Notes:
  −
// IE loses the cursor position in the textarea when the popup is used.
  −
// So we save the cursor position here
  −
function XEBgetIESelectedRange(){
  −
var IESel=new Object;
  −
var txtarea;
  −
if (document.editform) {
  −
txtarea = document.editform.wpTextbox1;
  −
} else {
  −
// some alternate form? take the first one we can find
  −
var areas = document.getElementsByTagName('textarea');
  −
  −
txtarea = areas[0];
  −
}
  −
// IE & Opera
  −
  −
if (document.selection  && !is_gecko)
  −
{
  −
txtarea.focus();
  −
IESel.Rng=document.selection.createRange();
  −
return IESel;
  −
}
  −
}
  −
  −
function XEBinsertText(beforeText,selText,afterText,IESelectedRange) {
  −
var newText=beforeText + selText + afterText;
  −
var txtarea;
  −
if (document.editform) {
  −
txtarea = document.editform.wpTextbox1;
  −
} else {
  −
// some alternate form? take the first one we can find
  −
var areas = document.getElementsByTagName('textarea');
  −
txtarea = areas[0];
  −
}
  −
  −
// IE
  −
if (document.selection  && !is_gecko) {
  −
  −
tr=IESelectedRange.Rng;
  −
tr.text=newText;
  −
txtarea.focus();
  −
//txtarea.caretpos=tr.duplicate();
  −
tr.select();
  −
  −
return;
  −
  −
// Mozilla
  −
} else if(txtarea.selectionStart || txtarea.selectionStart == '0') {
  −
var replaced = false;
  −
var startPos = txtarea.selectionStart;
  −
var endPos = txtarea.selectionEnd;
  −
  −
if (endPos-startPos) {
  −
replaced = true;
  −
}
  −
var scrollTop = txtarea.scrollTop;
  −
// var myText = (txtarea.value).substring(startPos, endPos);
  −
// if (!myText) {
  −
// myText=sampleText;
  −
// }
  −
// if (myText.charAt(myText.length - 1) == " ") { // exclude ending space char, if any
  −
// subst = tagOpen + myText.substring(0, (myText.length - 1)) + tagClose + " ";
  −
// } else {
  −
// subst = tagOpen + myText + tagClose;
  −
// }
  −
txtarea.value = txtarea.value.substring(0, startPos) + newText +
  −
txtarea.value.substring(endPos, txtarea.value.length);
  −
txtarea.focus();
  −
//set new selection
  −
if (!replaced) {
  −
var cPos = startPos+(newText.length);
  −
txtarea.selectionStart = cPos;
  −
txtarea.selectionEnd = cPos;
  −
} else {
  −
txtarea.selectionStart = startPos+beforeText.length;
  −
txtarea.selectionEnd = startPos+beforeText.length+selText.length;
  −
}
  −
txtarea.scrollTop = scrollTop;
  −
  −
// All other browsers get no toolbar.
  −
// There was previously support for a crippled "help"
  −
// bar, but that caused more problems than it solved.
  −
}
  −
// reposition cursor if possible
  −
if (txtarea.createTextRange) {
  −
  −
txtarea.caretPos = document.selection.createRange().duplicate();
  −
//txtarea.caretPos =IESelectedRange.Rng;
  −
}
  −
txtarea.focus();
  −
}
  −
  −
  −
//============================================================
  −
// Table generator
  −
//============================================================
  −
/** en: Generate an array using Mediawiki syntax
  −
* @author: originally from fr:user:dake
  −
* @version: 0.2 */
  −
function generateTable(caption, exhead, nbCol, nbRow, exfield, align){
  −
  −
};
  −
  −
  −
function XEBPopupRef(e){
  −
  −
m=new GetPos(e||event);
  −
  −
curPopup=new XEBPopup("ref",m.x,m.y);
  −
curPopup.width=500;
  −
mt='<p>Enter the reference parameters below: <\/p>'
  −
+'<form name="XEBPopupRefForm">'
  −
+'Name:<input type="text" name="refName" value="" size="10"><p\/>'
  −
+'Material:<input type="text" name="refMaterial" value="' + XEBGetSelectedText() + '" size="20">'
  −
+'<\/form>'
  −
+'<p><button onClick="javascript:insertRef()">Insert</button>'
  −
+'<button onClick="hideXEBPopup()">Cancel</button>';
  −
  −
curPopup.setInnerHTML(mt);
  −
// document.XEBPopupRefForm.refName.focus();
  −
return true;
  −
}
  −
  −
function insertRef(){
  −
f=document.XEBPopupRefForm;
  −
var refName = f.refName.value;
  −
var refMaterial=f.refMaterial.value;
  −
  −
hideXEBPopup();
  −
var code1='<ref';
  −
code1+=(refName)?' name="'+refName+'">':'>';
  −
code2=refMaterial;
  −
code3='<\/ref>'
  −
XEBinsertText(code1,code2,code3,curPopup.IESelectedRange);
  −
  −
extendSummary('ref');
  −
return false;
  −
}
  −
  −
//===GEO LINK Function==================================================
  −
  −
function XEBPopupGeoLink(e)
  −
{
  −
m=new GetPos(e||event);
  −
  −
curPopup=new XEBPopup("geo",m.x,m.y);
  −
curPopup.width=300;
  −
mt='<p>Enter the location parameters below: <\/p>'
  −
+'<form name="XEBPopupGeoLinkForm">'
  −
+'Loction:<p\/>'
  −
+'<table style="background: transparent;">'
  −
+'<tr><td>Latitude:<\/td><td><input type="text" autocomplete="off" name="geoLatDeg" value="" size="4"><\/td>'
  −
+'<td><input type="text" name="geoLatMin" size="4"><\/td>'
  −
+'<td><input type="text" name="geoLatSec" size="4"><\/td>'
  −
+'<td><select name="geoLatNS"><option value="N">N<option value="S">S</select><\/td><\/tr>'
  −
+'<tr><td>Longitude:<\/td><td><input type="text" name="geoLonDeg" value="" size="4"><\/td>'
  −
+'<td><input type="text" name="geoLonMin" value="" size="4"><\/td>'
  −
+'<td><input type="text" name="geoLonSec" value="" size="4"><\/td>'
  −
+'<td><select name="geoLonEW"><option value="E">E<option value="W">W</select><\/td><\/tr>'
  −
+'<\/table>'
  −
+'Region:<input type="text" name="geoRegion" value="" size="4"><p\/>'
  −
+'Type:'
  −
+'<SELECT NAME="geoType" size="5">'
  −
+'<OPTION VALUE="country">Country<OPTION VALUE="state">State'
  −
+'<OPTION VALUE="adm1st">Admin unit, 1st level<OPTION VALUE="adm2st">Admin unit, 2nd level'
  −
+'<OPTION VALUE="city">City<OPTION VALUE="airport">Airport'
  −
+'<OPTION VALUE="mountain">Mountain<OPTION VALUE="isle">Isle'
  −
+'<OPTION VALUE="waterbody">Waterbody<OPTION VALUE="landmark" SELECTED>Landmark'
  −
+'<OPTION VALUE="forest">forest</SELECT><br>'
  −
+'Title: <input type="checkbox" name="geoTitle" ><p\/>'
  −
+'<\/form>'
  −
+'<p><button onClick="javascript:insertGeoLink()">Insert</button>'
  −
+'<button onClick="hideXEBPopup()">Cancel</button>';
  −
  −
curPopup.setInnerHTML(mt);
  −
document.paramForm.refName.focus();
  −
return true;
  −
  −
}
  −
function insertGeoLink()
  −
{
  −
f=document.XEBPopupGeoLinkForm;
  −
  −
  −
var code='
  −
{{Coor ';
  −
if(f.geoTitle.checked)code+='title ';
  −
ft='dms';
  −
if(f.geoLatSec.value==''&&f.geoLonSec.value=='')ft='dm';
  −
if(ft=='dm'&&f.geoLatMin.value==''&&f.geoLonMin.value=='')ft='d';
  −
code+=ft;
  −
code+='|'+f.geoLatDeg.value;
  −
code+=(ft=='dm'||ft=='dms')?'|'+f.geoLatMin.value:'';
  −
code+=(ft=='dms')?'|'+f.geoLatSec.value:'';
  −
code+='|'+f.geoLatNS.value;
  −
code+='|'+f.geoLonDeg.value;
  −
code+=(ft=='dm'||ft=='dms')?'|'+f.geoLonMin.value:'';
  −
code+=(ft=='dms')?'|'+f.geoLonSec.value:'';
  −
code+='|'+f.geoLonEW.value;
  −
code+='|type:'+f.geoType.value+'_region:'+f.geoRegion.value code+='}}'
  −
;
  −
insertTags('','', code);
  −
extendSummary('geo-location');
  −
hideXEBPopup();
  −
return false;
  −
}
  −
  −
//===Talk Page entry Function===========================================
  −
  −
function XEBPopupTalk(e)
  −
{
  −
m=new GetPos(e||event);
  −
  −
curPopup=new XEBPopup("talk",m.x,m.y);
  −
curPopup.width=200;
  −
mt='<div style="font-size:medium"><p>Please choose:<\/p>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(1)">Test1<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(2)">Self Test<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(3)">Nonsense<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(4)">Please stop<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(5)">Last chance<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(6)">Blanking<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(7)">Blatant<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(8)">*BLOCKED*<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(9)">Spam<\/span><br>'
  −
mt+='<span class="XEBMnuItm" onclick="XEBInsertTalk(10)">Npov<\/span></div>'
  −
  −
curPopup.setInnerHTML(mt);
  −
  −
return true;
  −
  −
}
  −
function XEBInsertTalk(itm)
  −
{
  −
hideXEBPopup();
  −
if(itm==1)code='{{subst:test1-n|}}';
  −
if(itm==2)code='{{subst:selftest-n|}}';
  −
if(itm==3)code='{{subst:test2-n|}}';
  −
if(itm==4)code='{{subst:test3-n|}}';
  −
if(itm==5)code='{{subst:test4-n|}}';
  −
if(itm==6)code='{{subst:test2a-n|}}';
  −
if(itm==7)code='{{subst:bv-n|}}';
  −
if(itm==8)code='{{subst:blantant|}}';
  −
if(itm==9)code='{{subst:spam-n|}}';
  −
if(itm==10)code='{{subst:NPOV user}}';
  −
  −
insertTags('','', code);
  −
return false;
  −
}
  −
function XEBPopupImage(e)
  −
{
  −
m=new GetPos(e||event);
  −
  −
curPopup=new XEBPopup("image",m.x,m.y);
  −
curPopup.width=300;
  −
  −
mt='<p>Enter the image parameters below: <\/p>'
  −
+'<form name="XEBPopupImageForm">'
  −
+'File:<input type="text" name="imgFile" value="' + XEBGetSelectedText() + '" size="30"><br>'
  −
+'Type:<SELECT NAME="imgType">'
  −
+'<OPTION VALUE="thumb">Thumbnail'
  −
+'<OPTION VALUE="frame">Frame'
  −
+'<OPTION VALUE="none">[not specified]'
  −
+'</SELECT><br>'
  −
+'Location:<SELECT NAME="imgLocation">'
  −
+'<OPTION VALUE="left">Left'
  −
+'<OPTION VALUE="center">Centre'
  −
+'<OPTION VALUE="right">Right'
  −
+'<OPTION VALUE="none">None'
  −
+'</SELECT><br>'
  −
+'Size:<input type="text" name="imgSize" value="100" size="3">px<br>'
  −
+'Caption:<input type="text" name="imgCaption" value="" size="30"><\/p>'
  −
+'<\/form>'
  −
+'<p><button onClick="javascript:XEBInsertImage()">Insert</button>'
  −
+'<button onClick="hideXEBPopup()">Cancel</button>';
  −
  −
curPopup.setInnerHTML(mt);
  −
  −
return true;
  −
}
  −
function XEBInsertImage()
  −
{
  −
f=document.XEBPopupImageForm;
  −
hideXEBPopup();
  −
var code='[[Image:';
  −
code+=f.imgFile.value;
  −
code+='|'+f.imgType.value;
  −
code+='|'+f.imgLocation.value;
  −
code+='|'+f.imgSize.value;
  −
code+='|'+f.imgCaption.value;
  −
code+=']]';
  −
insertTags('','', code);
  −
extendSummary('image');
  −
  −
return false;
  −
}
  −
  −
function XEBPopupFormattedText(e)
  −
{
  −
m=new GetPos(e||event);
  −
  −
curPopup=new XEBPopup("image",m.x,m.y);
  −
curPopup.width=300;
  −
  −
mt='<form name="XEBPopupImageForm">'
  −
+'<table  style="background: transparent;">'
  −
+'<tr><td>Bold:<\/td><td><input type="checkbox" name="textBold"><\/td>'
  −
+'<td>Superscript:<\/td><td><input type="checkbox" name="textSuperscript"><\/td><\/tr>'
  −
+'<tr><td>Italic:<\/td><td><input type="checkbox" name="textItalic"><\/td>'
  −
+'<td>Subscript:<\/td><td><input type="checkbox" name="textSubscript"><\/td><\/tr>'
  −
+'<tr><td>Strike:<\/td><td><input type="checkbox" name="textStrike"><\/td>'
  −
+'<td>&nbsp;<\/td><\/tr>'
  −
+'</table>'
  −
+'Size:<SELECT NAME="textSize">'
  −
+'<OPTION VALUE="small">small'
  −
+'<OPTION VALUE="normal">[Normal]'
  −
+'<OPTION VALUE="big">big'
  −
+'</SELECT><br><table style="background:transparent;"><tr><td>Colour:<\/td><td>'
  −
+'<table width="100px">'
  −
+'<tr><td colspan="4">None<\/td></tr>'
  −
+'<tr><td bgcolor="aqua">&nbsp;<\/td><td bgcolor="gray"> &nbsp;<\/td>'
  −
+'<td bgcolor="olive">&nbsp;<\/td><td bgcolor="navy">&nbsp;<\/td><\/tr>'
  −
+'<tr><td bgcolor="black">&nbsp;<\/td><td bgcolor="green"> &nbsp;<\/td>'
  −
+'<td bgcolor="purple">&nbsp;<\/td><td bgcolor="teal">&nbsp;<\/td><\/tr>'
  −
+'<tr><td bgcolor="blue">&nbsp;<\/td><td bgcolor="lime">&nbsp;<\/td>'
  −
+'<td bgcolor="red">&nbsp;<\/td><td bgcolor="white">&nbsp;<\/td><\/tr>'
  −
+'<tr><td bgcolor="fuchsia">&nbsp;<\/td><td bgcolor="maroon">&nbsp;<\/td>'
  −
+'<td bgcolor="silver">&nbsp;<\/td><td bgcolor="yellow">&nbsp;<\/td><\/tr>'
  −
+'</table><\/td><\/tr>'
  −
+'<\/form>'
  −
+'Sample:'
  −
+'<span id="sampleText">Text</span>"'
  −
+'<p><button onClick="javascript:XEBInsertFormattedText()">Insert</button>'
  −
+'<button onClick="hideXEBPopup()">Cancel</button>';
  −
  −
curPopup.setInnerHTML(mt);
  −
  −
return true;
  −
}
  −
  −
function XEBUpdateSampleText()
  −
{
  −
f=document.XEBPopupImageForm;
  −
}
  −
  −
//====================
  −
  −
function XEBMenuMouseOut(e)
  −
{
  −
var targ;
  −
if (!e) var e = window.event;
  −
if (e.target) targ = e.target;
  −
else if (e.srcElement) targ = e.srcElement;
  −
  −
targ.style.color='black';
  −
}
  −
  −
function XEBMenuMouseOver(e)
  −
{ var targ;
  −
if (!e) var e = window.event;
  −
if (e.target) targ = e.target;
  −
else if (e.srcElement) targ = e.srcElement;
  −
  −
targ.style.color='red';
  −
}
  −
  −
//=======================================================================
  −
// Other functions
  −
//=======================================================================
  −
  −
function XEBgetElementsByClassName(parent,clsName,htmltag){
  −
var arr = new Array();
  −
var elems = parent.getElementsByTagName(htmltag);
  −
for ( var cls, i = 0; ( elem = elems[i] ); i++ ){
  −
if ( elem.className == clsName ){
  −
arr[arr.length] = elem;
  −
}
  −
}
  −
return arr;
  −
}
  −
  −
function extendSummary(newText)
  −
{
  −
if(!XEBExtendEditSummary)return;
  −
s=document.editform.elements['wpSummary'].value;
  −
s+=(s=='')?newText:' +'+newText;
  −
document.editform.elements['wpSummary'].value=s;
  −
}
  −
  −
function bug(msg)
  −
{
  −
if(wgUserName=='MarkS')alert(msg);
  −
}
  −
  −
  −
//</pre>