|
|
(19 intermediate revisions by the same user not shown) |
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. */ |
− |
| |
− | /**** Special:Upload enhancements ******
| |
− | * moved to [[MediaWiki:Upload.js]]
| |
− | *
| |
− | * Maintainer: [[User:Lupo]]
| |
− | ****/
| |
− | JSconfig.registerKey('UploadForm_loadform', true,
| |
− | {
| |
− | 'bg': 'Използване на логиката на новия формуляр за качвания',
| |
− | 'en': 'Use new upload form logic', // default
| |
− | 'mk': 'Искористете ја логиката на новиот образец за подигнување',
| |
− | 'ru': 'Использовать новую логику формы загрузки'
| |
− | }, 3);
| |
− | JSconfig.registerKey('UploadForm_newlayout', true,
| |
− | {
| |
− | 'bg': 'Използване на облика на новия формуляр за качвания',
| |
− | 'en': 'Use new upload form layout', // default
| |
− | 'mk': 'Искористете го рувото на новиот образец за подигнување',
| |
− | 'ru': 'Использовать новый интерфейс формы загрузки'
| |
− | }, 3);
| |
− |
| |
− | function enableNewUploadForm ()
| |
− | {
| |
− | var match = navigator.userAgent.match(/AppleWebKit\/(\d+)/);
| |
− | if (match) {
| |
− | var webKitVersion = parseInt(match[1]);
| |
− | if (webKitVersion < 420) return; // Safari 2 crashes hard with the new upload form...
| |
− | }
| |
− |
| |
− | // honor JSConfig user settings
| |
− | if( !JSconfig.keys['UploadForm_loadform'] ) return;
| |
− |
| |
− | importScript( 'MediaWiki:UploadForm.js' );
| |
− | }
| |
− |
| |
− | if (wgPageName == 'Special:Upload')
| |
− | {
| |
− | importScript( 'MediaWiki:Upload.js' );
| |
− | // Uncomment the following line (the call to enableNewUploadForm) to globally enable the
| |
− | // new upload form. Leave the line *above* (the include of MediaWiki:Upload.js) untouched;
| |
− | // that script provides useful default behavior if the new upload form is disabled or
| |
− | // redirects to the old form in case an error occurs.
| |
− | enableNewUploadForm ();
| |
− | }
| |
− |
| |
− | // We may be running MediaWiki:UploadForm.js on this site. The following script changes the
| |
− | // "reupload" links on image pages to go to the basic form.
| |
− | if (wgNamespaceNumber == 6) importScript ('MediaWiki:UploadFormLinkFixer.js');
| |
− |
| |
− | 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',' ','',''],
| |
− | '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> <\/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"> <\/td><td bgcolor="gray"> <\/td>'
| |
− | +'<td bgcolor="olive"> <\/td><td bgcolor="navy"> <\/td><\/tr>'
| |
− | +'<tr><td bgcolor="black"> <\/td><td bgcolor="green"> <\/td>'
| |
− | +'<td bgcolor="purple"> <\/td><td bgcolor="teal"> <\/td><\/tr>'
| |
− | +'<tr><td bgcolor="blue"> <\/td><td bgcolor="lime"> <\/td>'
| |
− | +'<td bgcolor="red"> <\/td><td bgcolor="white"> <\/td><\/tr>'
| |
− | +'<tr><td bgcolor="fuchsia"> <\/td><td bgcolor="maroon"> <\/td>'
| |
− | +'<td bgcolor="silver"> <\/td><td bgcolor="yellow"> <\/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>
| |