Sarna News: Bad 'Mechs - Icestorm

Difference between revisions of "MediaWiki:Common.js/edit.js"

m
Line 41: Line 41:
  
 
/***********************************************************
 
/***********************************************************
  * Extra toolbar options
+
  * Extra toolbar options
 
  *
 
  *
  * Description: Adds extra buttons to the editing toolbar.
+
  * Description: Adds extra buttons to the editing toolbar.
 
  ***********************************************************/
 
  ***********************************************************/
 
if (mwCustomEditButtons) {
 
if (mwCustomEditButtons) {
Line 121: Line 121:
 
     });
 
     });
  
  if (isTesting) {  
+
    if (window.jQuery != undefined) {  
    var menus = new Array(symbols, templates);
+
        var menus = new Array(symbols, templates);
  
    addOnloadHook(function(){
+
        addOnloadHook(function(){
        insertToolbarExtras(menus);
+
            insertToolbarExtras(menus);
    });
+
        });
  }
+
    }
 
}
 
}
  
/***********************************************************
+
/******************************************************
  * insertToolbarExtras()
+
  * insertToolbarExtras()
 
  *
 
  *
  *  @param menus (array)  
+
  * Description: Creates a <div> placed above the edit
  ***********************************************************/
+
*  form and fills it with toolbar menus.
 +
*  Requires jQuery JavaScript library.
 +
*
 +
  * @author  ebakunin
 +
* @param   menus (array)  
 +
  ******************************************************/
 
function insertToolbarExtras(menus)
 
function insertToolbarExtras(menus)
 
{
 
{
Line 150: Line 155:
 
};
 
};
  
/***********************************************************
+
/*********************************************************
  * insertToolbarHeader()
+
  * insertToolbarHeader()
 
  *
 
  *
  *  @param menu (array)  
+
  * Description: Inserts the name of the toolbar extra
  ***********************************************************/
+
*  section. Clicking on the header shows/hides the
 +
*  related section. Requires jQuery JavaScript library.
 +
  *
 +
* @author  ebakunin
 +
* @param   menu (array)
 +
  *********************************************************/
 
function insertToolbarHeader(menu)
 
function insertToolbarHeader(menu)
 
{
 
{
Line 160: Line 170:
 
};
 
};
  
/***********************************************************
+
/****************************************************
  * insertToolbarMenu()
+
  * insertToolbarMenu()
 
  *
 
  *
  *  @param list (array)  
+
  * Description: Creates a hidden <div> and fills it
  ***********************************************************/
+
*  with insertable characters.
 +
*  Requires jQuery JavaScript library.
 +
*
 +
* @author  ebakunin
 +
  * @param   list (array)  
 +
  ****************************************************/
 
function insertToolbarMenu(list)
 
function insertToolbarMenu(list)
 
{
 
{
Line 183: Line 198:
 
};
 
};
  
/***********************************************************
+
/********************************************************
  * wrapToolbarCharacter()
+
* wrapToolbarCharacter()
 +
*
 +
* Description: Places an <a> tag around a character to
 +
  *   call insertTags() from the "CharInsert" extension.
 
  *
 
  *
  *  @param char (string)  
+
  * @author  ebakunin
  ***********************************************************/
+
  * @param   char (string)  
 +
  ********************************************************/
 
function wrapToolbarCharacter(char)
 
function wrapToolbarCharacter(char)
 
{
 
{

Revision as of 00:24, 22 July 2009

/* Any JavaScript here will be loaded for all users on all edit pages. */
//<source lang="javascript">

/******** GLOBAL VARIABLES ********/
/*** Symbol information list ***/
var symbols = new Array();
symbols["id"] = "symbols_box";
symbols["header"] = "Insert a character";
symbols["sections"] = new Array();

symbols["sections"]["nonstandard"] = new Array();
symbols["sections"]["nonstandard"]["title"] = "Symbols";
symbols["sections"]["nonstandard"]["items"] = new Array("–", "—", " ", "¡", "¿", "†", "‡", "§", "Ø", "ø", " ", "·", " ", "←", "→", "↑", "↓", " ", "½", "⅓", "⅔", "¼", "¾", "⅛", "⅜", "⅝", "⅞");

symbols["sections"]["vowels"] = new Array();
symbols["sections"]["vowels"]["title"] = "Vowels"
symbols["sections"]["vowels"]["items"] = new Array("Á", "á", "À", "à", "Ã", "ã", " ", "É", "é", "È", "è", "Ẽ", "ẽ", " ", "Í", "í", "Ì", "ì", "Ĩ", "ĩ", " ", "Ó", "ó", "Ò", "ò", "Õ", "õ", " ", "Ú", "ú", "Ù", "ù", "Ũ", "ũ");

symbols["sections"]["consonants"] = new Array();
symbols["sections"]["consonants"]["title"] = "Consonants"
symbols["sections"]["consonants"]["items"] = new Array("Ć", "ć", "Ç", "ç", " ", "Ģ", "ģ", " ", "Ķ", "ķ", " ", "Ĺ", "ĺ", "Ļ", "ļ", " ", "Ń", "ń", "Ñ", "ñ", "Ņ", "ņ", " ", "Ŕ", "ŕ", "Ŗ", "ŗ", " ", "Ś", "ś", "Ş", "ş", " ", "Ţ", "ţ", " ", "Ý", "ý", "Ỹ", "ỹ", " ", "Ź", "ź", " ", "ß", "Đ", "đ");

/*** Template information list ***/
var templates = new Array();
templates["id"] = "templates_box";
templates["header"] = "Insert a template";
templates["sections"] = new Array();

templates["sections"]["stubs"] = new Array();
templates["sections"]["stubs"]["title"] = "Stubs";
templates["sections"]["stubs"]["items"] = new Array("{{stub}}", "{{sectionstub}}");

templates["sections"]["notices"] = new Array();
templates["sections"]["notices"]["title"] = "Notices";
templates["sections"]["notices"]["items"] = new Array("{{Citation needed}}", "{{Update Needed}}", "{{Cleanup}}", "{{Verify}}", "{{NonCanon}}", "{{Moratorium}}");

templates["sections"]["misc"] = new Array();
templates["sections"]["misc"]["title"] = "Miscellaneous";
templates["sections"]["misc"]["items"] = new Array("{{disambig}}", "{{quote| }}", "{{yearlist}}", "{{otheruses| | | }}");


/***********************************************************
 * Extra toolbar options
 *
 * Description: Adds extra buttons to the editing toolbar.
 ***********************************************************/
if (mwCustomEditButtons) {
    mwCustomEditButtons.push({
        "imageId": "mw-editbutton-br",
        "imageFile": "http://sarna.net/wiki/images/1/13/Button_enter.png",
        "speedTip": "Line break",
        "tagOpen": "<br />",
        "tagClose": "",
        "sampleText": ""
    });
 
    mwCustomEditButtons.push({
        "imageFile": "http://sarna.net/wiki/images/6/6a/Button_sup_letter.png",
        "speedTip": "Superscript",
        "tagOpen": "<sup>",
        "tagClose": "</sup>",
        "sampleText": "Superscript text"
    });
 
    mwCustomEditButtons.push({
        "imageFile": "http://sarna.net/wiki/images/a/aa/Button_sub_letter.png",
        "speedTip": "Subscript",
        "tagOpen": "<sub>",
        "tagClose": "</sub>",
        "sampleText": "Subscript text"
    });
 
    mwCustomEditButtons.push({
        "imageFile": "http://sarna.net/wiki/images/1/17/Button_small_2.png",
        "speedTip": "Small text",
        "tagOpen": "<small>",
        "tagClose": "</small>",
        "sampleText": "Small text"
    });

    mwCustomEditButtons.push({
        "imageFile": "http://sarna.net/wiki/images/c/c8/Button_redirect.png",
        "speedTip": "Redirect",
        "tagOpen": "#REDIRECT[[",
        "tagClose": "]]",
        "sampleText": "Target page name"
    });
 
    mwCustomEditButtons.push({
        "imageFile": "http://sarna.net/wiki/images/1/12/Button_gallery.png",
        "speedTip": "Insert a picture gallery",
        "tagOpen": "\n<gallery>\n",
        "tagClose": "\n</gallery>",
        "sampleText": "Image:Example.jpg|Caption1\nImage:Example.jpg|Caption2"
    });
 
    mwCustomEditButtons.push({
        "imageFile": "http://sarna.net/wiki/images/6/60/Button_insert_table.png",
        "speedTip": "Insert a table",
        "tagOpen": '{| class="wikitable" border="1"\n|',
        "tagClose": "\n|}",
        "sampleText": "-\n! header 1\n! header 2\n! header 3\n|-\n| row 1, cell 1\n| row 1, cell 2\n| row 1, cell 3\n|-\n| row 2, cell 1\n| row 2, cell 2\n| row 2, cell 3"
    });

    mwCustomEditButtons.push({
        "imageId": "mw-editbutton-ref",
        "imageFile": "http://sarna.net/wiki/images/7/79/Button_reflink.png",
        "speedTip": "Insert a reference (requires a reference footer)",
        "tagOpen": "<ref>",
        "tagClose": "</ref>",
        "sampleText": "Insert footnote text here"
    });

    mwCustomEditButtons.push({
        "imageId": "mw-editbutton-references",
        "imageFile": "http://sarna.net/wiki/images/f/f7/Button_referencesR.png",
        "speedTip": "Insert the reference footer",
        "tagOpen": "<references />",
        "tagClose": "",
        "sampleText": ""
    });

    if (window.jQuery != undefined) { 
        var menus = new Array(symbols, templates);

        addOnloadHook(function(){
            insertToolbarExtras(menus);
        });
    }
}

/******************************************************
 * insertToolbarExtras()
 *
 * Description: Creates a <div> placed above the edit 
 *   form and fills it with toolbar menus.
 *   Requires jQuery JavaScript library.
 *
 * @author  ebakunin
 * @param   menus (array) 
 ******************************************************/
function insertToolbarExtras(menus)
{
    var code = '<div id="toolbar-menu-header">';
    for (var i=0; i < menus.length; i++) {
        code += insertToolbarHeader(menus[i]);
    }
    code += '</div>';

    for (var i=0; i < menus.length; i++) {
        code += insertToolbarMenu(menus[i]);
    }

    $("#editform").prepend(code);
};

/*********************************************************
 * insertToolbarHeader()
 *
 * Description: Inserts the name of the toolbar extra
 *   section. Clicking on the header shows/hides the
 *   related section. Requires jQuery JavaScript library.
 * 
 * @author  ebakunin
 * @param   menu (array)
 *********************************************************/
function insertToolbarHeader(menu)
{
    return "<span onclick=\"$('#" + menu['id'] + "').slideToggle('fast')\">" + menu['header'] + "</span>";
};

/****************************************************
 * insertToolbarMenu()
 *
 * Description: Creates a hidden <div> and fills it 
 *   with insertable characters.
 *   Requires jQuery JavaScript library.
 *
 * @author  ebakunin
 * @param   list (array) 
 ****************************************************/
function insertToolbarMenu(list)
{
    var insert = '<div id="' + list["id"] + '" class="toolbar-menu">';

    for (var i in list['sections']) {
        insert += "<strong>" + list['sections'][i]['title'] + "</strong>: ";

        for (var j=0; j < list['sections'][i]['items'].length; j++) {
            insert += wrapToolbarCharacter(list['sections'][i]['items'][j]);
        }
        insert += "<br />";
    }

    insert += "</div>";

    return insert;
};

/********************************************************
 * wrapToolbarCharacter()
 *
 * Description: Places an <a> tag around a character to 
 *   call insertTags() from the "CharInsert" extension.
 *
 * @author  ebakunin
 * @param   char (string) 
 ********************************************************/
function wrapToolbarCharacter(char)
{
    return (char == " " || char == "&nbsp;")
      ? ' &nbsp; '
      : '<a title="Click on the character or tag to insert it into the edit window" href="javascript:insertTags(\'' + char + '\',\'\',\'\')">' + char + '</a> &nbsp;';
};

//</source>