"മീഡിയവിക്കി:Common.js" എന്ന താളിന്റെ പതിപ്പുകൾ തമ്മിലുള്ള വ്യത്യാസം

Sabarish (സംവാദം | സംഭാവനകൾ)
No edit summary
No edit summary
 
(4 ഉപയോക്താക്കൾ ചെയ്ത ഇടയ്ക്കുള്ള 99 നാൾപ്പതിപ്പുകൾ പ്രദർശിപ്പിക്കുന്നില്ല)
വരി 1: വരി 1:
/** Main Page layout fixes *********************************************************
mw.loader.load('//en.wikipedia.org/w/index.php?title=User:Joeytje50/JWB.js/load.js&action=raw&ctype=text/javascript');
*
*  Description:        Various layout fixes for the main page, including an
*                      additional link to the complete list of languages available
*                      and the renaming of the 'Article' to to 'Main Page'.
*  Maintainers:        User:AzaToth, User:R. Koot
*/


function mainPageRenameNamespaceTab() {
/* ============================================================
     try {
  OpenStreetMap marker URL fix
        var Node = document.getElementById( 'ca-nstab-main' ).firstChild;
  ============================================================ */
        if ( Node.textContent ) {     // Per DOM Level 3
window.onload = function () {
            Node.textContent = 'പ്രധാന താള്‍';
     var images = document.querySelectorAll('img');
         } else if ( Node.innerText ) { // IE doesn't handle .textContent
    for (var i = 0; i < images.length; i++) {
             Node.innerText = 'പ്രധാന താള്‍';
        var img = images[i];
        } else {                      // Fallback
         if (
            Node.replaceChild( Node.firstChild, document.createTextNode( 'പ്രധാന താള്‍' ) );  
            img.src &&
            img.src.startsWith("https://tile.openstreetmap.org/v4/marker/")
        ) {
             img.src = img.src.replace(
                'https://tile.openstreetmap.org/v4/marker/',
                'https://maps.wikimedia.org/v4/marker/'
            );
         }
         }
    } catch(e) {
};
        // bailing out!
};
    }
 
}
/* ============================================================
  Wikimedia Commons Gallery Loader (Template-based, MULTILINE SAFE)
  ============================================================ */
mw.hook('wikipage.content').add(function ($content) {


function mainPageAppendCompleteListLink() {
     $content.find('.commons-gallery').each(function () {
     try {
        var container = this;
        var node = document.getElementById( "p-lang" )
                          .getElementsByTagName('div')[0]
                          .getElementsByTagName('ul')[0];


         var aNode = document.createElement( 'a' );
         var sources = container.querySelectorAll('.commons-gallery-source');
         var liNode = document.createElement( 'li' );
         if (!sources.length) return;


         aNode.appendChild( document.createTextNode( 'Complete list' ) );
         var width = 300;
        aNode.setAttribute( 'href' , 'http://meta.wikimedia.org/wiki/List_of_Wikipedias ' );
        liNode.appendChild( aNode );
        liNode.className = 'interwiki-completelist';
        node.appendChild( liNode );
    } catch(e) {
      // lets just ignore what's happened
      return;
    }
}


if ( wgTitle == 'പ്രധാന താള്‍' && ( wgNamespaceNumber == 0 || wgNamespaceNumber == 1 ) ) {
        var grid = document.createElement('div');
      addOnloadHook( mainPageRenameNamespaceTab );
        grid.className = 'commons-gallery-grid';
}
        grid.style.display = 'grid';
        grid.style.gridTemplateColumns =
            'repeat(auto-fill, minmax(' + width + 'px, 1fr))';
        grid.style.gap = '8px';


if ( wgTitle == 'പ്രധാന താള്‍' && wgNamespaceNumber == 0 ) {
        container.appendChild(grid);
      addOnloadHook( mainPageAppendCompleteListLink );
}


/**<pre><nowiki>*/
        sources.forEach(function (srcEl) {
/** Extra toolbar options ******************************************************
            var filename = srcEl.dataset.file;
  *
            var captionText = srcEl.dataset.caption || '';
  *  Description: UNDOCUMENTED
  *  Maintainers: [[User:MarkS]]?, [[User:Voice of All]], [[User:R. Koot]]
  */
//This is a modified copy of a script by User:MarkS for extra features added by User:Voice of All.
// This is based on the original code on Wikipedia:Tools/Editing tools
// To disable this script, add <code>mwCustomEditButtons = [];<code> to [[Special:Mypage/monobook.js]]
if (mwCustomEditButtons) {
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/c/c8/Button_redirect.png",
    "speedTip": "Redirect",
    "tagOpen": "#REDIRECT [[",
    "tagClose": "]]",
    "sampleText": "Insert text"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/c/c9/Button_strike.png",
    "speedTip": "Strike",
    "tagOpen": "<s>",
    "tagClose": "</s>",
    "sampleText": "Strike-through text"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/1/13/Button_enter.png",
    "speedTip": "Line break",
    "tagOpen": "<br />",
    "tagClose": "",
    "sampleText": ""};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/8/80/Button_upper_letter.png",
    "speedTip": "Superscript",
    "tagOpen": "<sup>",
    "tagClose": "</sup>",
    "sampleText": "Superscript text"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/7/70/Button_lower_letter.png",
    "speedTip": "Subscript",
    "tagOpen": "<sub>",
    "tagClose": "</sub>",
    "sampleText": "Subscript text"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/5/58/Button_small.png",
    "speedTip": "Small",
    "tagOpen": "<small>",
    "tagClose": "</small>",
    "sampleText": "Small Text"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/3/34/Button_hide_comment.png",
    "speedTip": "Insert hidden Comment",
    "tagOpen": "<!-- ",
    "tagClose": " -->",
    "sampleText": "Comment"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/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[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/f/fd/Button_blockquote.png",
    "speedTip": "Insert block of quoted text",
    "tagOpen": "<blockquote>\n",
    "tagClose": "\n</blockquote>",
    "sampleText": "Block quote"};
  mwCustomEditButtons[mwCustomEditButtons.length] = {
    "imageFile": "http://upload.wikimedia.org/wikipedia/en/6/60/Button_insert_table.png",
    "speedTip": "Insert a table",
    "tagOpen": '{| class="wikitable"\n|-\n',
    "tagClose": "\n|}",
    "sampleText": "! 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[mwCustomEditButtons.length] = {
            if (!filename) return;
    "imageFile": "http://upload.wikimedia.org/wikipedia/ml/2/20/Button_subst.png",
    "speedTip": "സബ്സ്റ്റിറ്റിയൂഷന്‍ (subst) ചേര്‍ക്കുക",
    "tagOpen": "{{ബദല്‍:",
    "tagClose": "}}",
    "sampleText": "സ്വാഗതം"};


  mwCustomEditButtons[mwCustomEditButtons.length] = {
            var apiUrl =
    "imageFile": "http://upload.wikimedia.org/wikipedia/commons/7/79/Button_reflink.png",
                'https://commons.wikimedia.org/w/api.php' +
    "speedTip": "റഫറന്‍‌സുകള്‍ നല്‍കാന്‍",
                '?action=query' +
    "tagOpen": "<ref>\n",
                '&format=json' +
    "tagClose": "\n</ref>",
                '&prop=imageinfo' +
    "sampleText": "References"};
                '&iiprop=url|extmetadata' +
                '&iiurlwidth=' + width +
                '&titles=File:' + encodeURIComponent(filename) +
                '&origin=*';


}
            fetch(apiUrl)
/*</nowiki></pre>*/
                .then(function (r) {
                    if (!r.ok) throw new Error('HTTP ' + r.status);
                    return r.json();
                })
                .then(function (data) {
                    if (!data || !data.query || !data.query.pages) return;


/*<pre><nowiki>
                    var page =
ടൂള്‍ ബാര്‍ ബട്ടണുകള്‍ അടുക്കിപ്പെറുക്കി വയ്ക്കാനുള്ള സ്ക്രിപ്റ്റ്‌
                        data.query.pages[Object.keys(data.query.pages)[0]];
Maintainer : [[User:Tux the penguin]]
                    if (!page || !page.imageinfo) return;
*/
function lija_rearrange()
{
var def,ext;
if(mwEditButtons)
def=mwEditButtons;


if(mwCustomEditButtons)
                    var info = page.imageinfo[0];
ext=mwCustomEditButtons;
                    var imgUrl = info.thumburl || info.url;


if(def!=null && ext!=null)
                    var artist = 'Unknown';
{
                    var license = '';
var defc=def.slice();
                    var licenseUrl = '';
var extc=ext.slice();
                    var commonsUrl = info.descriptionurl || '';
try
  {
def[2]=extc[1];
def[3]=defc[4];
def[4]=extc[8];
def[5]=extc[5];
def[6]=extc[9];
def[7]=extc[2];
def[8]=defc[10];
def[9]=extc[6];
def[10]=defc[8];
def[def.length]={
    "imageFile": "http://upload.wikimedia.org/wikipedia/commons/8/88/Btn_toolbar_enum.png",
    "speedTip": "എണ്ണമിട്ട പട്ടിക",
    "tagOpen": "\n#",
    "tagClose": "\n#രണ്ടാമത്തെ ഇനം\n#മൂന്നാമത്തെ ഇനം",
    "sampleText": "ഒന്നാമത്തെ ഇനം"};
def[def.length]={
    "imageFile": "http://upload.wikimedia.org/wikipedia/commons/1/11/Btn_toolbar_liste.png",
    "speedTip": "എണ്ണമിടാത്ത പട്ടിക",
    "tagOpen": "\n*",
    "tagClose": "\n*രണ്ടാമത്തെ ഇനം\n*മൂന്നാമത്തെ ഇനം",
    "sampleText": "ഒന്നാമത്തെ ഇനം"};
def[def.length]={
    "imageFile": "http://upload.wikimedia.org/wikipedia/commons/b/b4/Button_category03.png",
    "speedTip": "സൂചിക ചേര്‍ക്കുക",
    "tagOpen": "[[Category:",
    "tagClose": "]]",
    "sampleText": "ഉള്ളടക്കം"};


ext[0]=defc[2];
                    if (info.extmetadata) {
ext[1]=defc[3];
                        if (info.extmetadata.Artist) {
ext[2]=defc[5];
                            artist = info.extmetadata.Artist.value;
ext[3]=defc[6];
                        }
ext[4]=extc[7];
                        if (info.extmetadata.LicenseShortName) {
ext[5]=defc[7];
                            license = info.extmetadata.LicenseShortName.value;
ext[6]=extc[3];
                        }
ext[7]=extc[4];
                        if (info.extmetadata.LicenseUrl) {
ext[8]=extc[0];
                            licenseUrl = info.extmetadata.LicenseUrl.value;
ext[9]=extc[10];
                        }
ext[10]=extc[11];
                    }
ext[11]=defc[9];
}
catch(ex)
{
//എറര്‍ ഉണ്ടായാല്‍..... സഹിക്കുക. അല്ലാണ്ടെന്തു ചെയ്യാന്‍ ?
}
}


                    var figure = document.createElement('figure');
                    figure.className = 'commons-gallery-item';


}
                    var img = document.createElement('img');
                    img.src = imgUrl;
                    img.alt = captionText || filename;
                    img.loading = 'lazy';
                    img.style.width = '100%';


addOnloadHook(lija_rearrange);
                    /* Lightbox source: responsive, not original */
//****************************************************************************************************************
                    var lightboxSrc = info.url;
//ടൂള്‍ ബാര്‍ സ്ക്രിപ്റ്റ്‌ ഇവിടെ അവസാനിയ്ക്കുന്നു.  
                    if (info.responsiveUrls) {
//****************************************************************************************************************
                        if (window.devicePixelRatio > 1 && info.responsiveUrls['2']) {
/*</nowiki></pre>*/
                            lightboxSrc = info.responsiveUrls['2'];
                        } else if (info.responsiveUrls['1.5']) {
                            lightboxSrc = info.responsiveUrls['1.5'];
                        }
                    }


                    img.dataset.fullsrc = lightboxSrc;
                    img.dataset.caption =
                        (captionText ? captionText + '<br>' : '') +
                        '© ' + artist +
                        (licenseUrl
                            ? ' – <a href="' + licenseUrl +
                              '" target="_blank" rel="noopener noreferrer">' +
                              license + '</a>'
                            : '') +
                        (commonsUrl
                            ? '<br><a href="' + commonsUrl +
                              '" target="_blank" rel="noopener noreferrer">' +
                              'View on Wikimedia Commons</a>'
                            : '');


/*
                    figure.appendChild(img);
<nowiki><pre>


    This script is a modified version of Alex benenson's cyrillic translitarator and this version was created by [[User:Peringz|Peringz]]
                    var figcaption = document.createElement('figcaption');
*/
                    figcaption.style.fontSize = '0.75em';
                    figcaption.style.textAlign = 'center';
                    figcaption.innerHTML = img.dataset.caption;


var consonants = {"ക":"ക","ഖ":"ഖ","ഗ":"ഗ","ഘ":"ഘ","ങ":"ങ","ച":"ച","ഛ":"ഛ","ജ":"ജ","ഝ":"ഝ","ഞ":"ഞ","ട":"ട","ഠ":"ഠ","ഡ":"ഡ","ഢ":"ഢ","ണ":"ണ","ത":"ത","ഥ":"ഥ","ദ":"ദ","ധ":"ധ","ന":"ന","പ":"പ","ഫ":"ഫ","ബ":"ബ","ഭ":"ഭ","മ":"മ","യ":"യ","ര":"ര","ല":"ല","വ":"വ","ശ":"ശ","ഷ":"ഷ","സ":"സ","ഹ":"ഹ","ള":"ള","ഴ":"ഴ","റ":"റ","റ്റ":"റ്റ"};
                    figure.appendChild(figcaption);
var chillaksharam = {"ണ്‍":"ണ","ന്‍":"ന","ം":"മ","ര്‍":"ര","ല്‍":"ല","ള്‍":"ള","്\\u200D":""};
                    grid.appendChild(figure);
                })
                .catch(function (err) {
                    console.warn(
                        'Commons gallery image failed:',
                        filename,
                        err.message
                    );
                });
        });


var vowels = '"്a":"","്e":"െ","്i":"ി","്o":"ൊ","്u":"ു","്A":"ാ","്E":"േ","്I":"ീ","്O":"ോ","്U":"ൂ","്Y":"ൈ","െe":"ീ","ൊo":"ൂ","ിi":"ീ","ിe":"ീ","ുu":"ൂ","ുo":"ൂ","്r":"്ര്",';
        /* Hide source placeholders */
var roman = '"k":"ക്","ക്h":"ഖ്","g":"ഗ്","ഗ്h":"ഘ്","ന്‍g":"ങ്","c":"ക്\\u200D","ക്\\u200Dh":"ച്","ച്h":"ഛ്","j":"ജ്","ജ്h":"ഝ്","ന്‍j":"ഞ്","ന്‍h":"ഞ്","T":"ട്","ട്h":"ഠ്","D":"ഡ്","ഡ്h":"ഢ്","റ്റ്h":"ത്","ത്h":"ഥ്","d":"ദ്","ദ്h":"ധ്","p":"പ്","പ്h":"ഫ്","f":"ഫ്","b":"ബ്","ബ്h":"ഭ്","y":"യ്","v":"വ്","w":"വ്","z":"ശ്","S":"ശ്","സ്h":"ഷ്","s":"സ്","h":"ഹ്","ശ്h":"ഴ്","x":"ക്ഷ്","R":"റ്","t":"റ്റ്",';
        sources.forEach(function (el) {
var chill = '"N":"ണ്‍","n":"ന്‍","m":"ം","r":"ര്‍","l":"ല്‍","L":"ള്‍",';
            el.style.display = 'none';
var swaram = '"a":"അ","അa":"ആ","A":"ആ","e":"എ","E":"ഏ","എe":"ഈ","i":"ഇ","ഇi":"ഈ","ഇe":"ഈ","അi":"ഐ","I":"ഐ","o":"ഒ","ഒo":"ഊ","O":"ഓ","അu":"ഔ","ഒu":"ഔ","u":"ഉ","ഉu":"ഊ","U":"ഊ","H":"ഃ","റ്h":"ഋ","ര്‍^":"ഋ","ഋ^":"ൠ","ല്‍^":"ഌ","ഌ^":"ൡ",';
        });
//var numerals = '"1":"൧","2":"൨","3":"൩","4":"൪","5":"൫","6":"൬","7":"൭","8":"൮","9":"൯","0":"൦",';
    });
var conjuncts = '"ന്‍t":"ന്റ്","ന്റ്h":"ന്ത്","ന്‍k":"ങ്ക്","ന്‍n":"ന്ന്","ണ്‍N":"ണ്ണ്","ള്‍L":"ള്ള്","ല്‍l":"ല്ല്","ംm":"മ്മ്","ന്‍m":"ന്മ്","ന്ന്g":"ങ്ങ്","ന്‍d":"ന്ദ്","ണ്‍m":"ണ്മ്","ല്‍p":"ല്പ്","ംp":"മ്പ്","റ്റ്t":"ട്ട്","ന്‍T":"ണ്ട്","ണ്‍T":"ണ്ട്","്ര്^":"ൃ","ന്‍c":"ന്‍\\u200D","ന്‍\\u200Dh":"ഞ്ച്","ണ്‍D":"ണ്ഡ്",';
});
var others = '"്L":"്ല്","~":"്\\u200C","്~":"\\u200C", "\\u200C~":"\\u200C", "\\u200D\\u200C":"\\u200D", "\\u200C_":"__", "___":"___","~":"്","ക്\\u200Dc":"ക്ക്\\u200D","ക്ക്\\u200Dh":"ച്ച്","q":"ക്യൂ",';
var caps = '"B":"ബ്ബ്","C":"ക്ക്\\u200D","F":"ഫ്","G":"ഗ്ഗ്","J":"ജ്ജ്","K":"ക്ക്","M":"മ്മ്","P":"പ്പ്","Q":"ക്യൂ","V":"വ്വ്","W":"വ്വ്","X":"ക്ഷ്","Y":"യ്യ്","Z":"ശ്ശ്",';
var ZWNJ = '"_":"\\u200C"';


// for compatibility with bookmarklets
/* ============================================================
function cyr_translit(src) {
  Commons Gallery Lightbox Viewer (with navigation)
    return to_cyrillic(src);
  ============================================================ */
}
(function () {


var conversionHash = undefined;
    var galleryImages = [];
var maxcyrlength = 0;
    var currentIndex = -1;


function getConversionHash() {
    function collectGalleryImages() {
    if (conversionHash == undefined) {
         galleryImages = Array.prototype.slice.call(
         // TODO
             document.querySelectorAll('.commons-gallery-item img')
        var opr = "{" + vowels + roman + chill + swaram +  conjuncts + caps + others;
         );
        for (var consonant in consonants) {
        opr += '"' + consonant + 'a":"' + consonant + 'ാ",';
        opr += '"' + consonant + 'e":"' + consonant + 'േ",';
        opr += '"' + consonant + 'i":"' + consonant + 'ൈ",';
        opr += '"' + consonant + 'o":"' + consonant + 'ോ",';
        opr += '"' + consonant + 'u":"' + consonant + 'ൗ",';
        }
        for (var chk in chillaksharam) {
             opr += '"' + chk + 'a":"' + chillaksharam[chk] + '",';
            opr += '"' + chk + 'e":"' + chillaksharam[chk] + 'െ",';
            opr += '"' + chk + 'i":"' + chillaksharam[chk] + 'ി",';
            opr += '"' + chk + 'o":"' + chillaksharam[chk] + 'ൊ",';
            opr += '"' + chk + 'u":"' + chillaksharam[chk] + 'ു",';
            opr += '"' + chk + 'A":"' + chillaksharam[chk] + 'ാ",';
            opr += '"' + chk + 'E":"' + chillaksharam[chk] + 'േ",';
            opr += '"' + chk + 'I":"' + chillaksharam[chk] + 'ീ",';
            opr += '"' + chk + 'O":"' + chillaksharam[chk] + 'ോ",';
            opr += '"' + chk + 'U":"' + chillaksharam[chk] + 'ൂ",';
            opr += '"' + chk + 'Y":"' + chillaksharam[chk] + 'ൈ",';
            opr += '"' + chk + 'r":"' + chillaksharam[chk] + '്ര്",';
            opr += '"' + chk + 'y":"' + chillaksharam[chk] + '്യ്",';
            opr += '"' + chk + 'v":"' + chillaksharam[chk] + '്വ്",';
            opr += '"' + chk + 'w":"' + chillaksharam[chk] + '്വ്",';
            opr += '"' + chk + '~":"' + chillaksharam[chk] + '്\\u200C",';
        }
        opr += ZWNJ + "}";
        // var tb = document.getElementById('wpTextbox1');
        // tb.value = opr;
         conversionHash = eval("("+opr+")");
        maxcyrlength=6;
     }
     }


     return conversionHash;
     function createLightbox() {
}
         if (document.getElementById('commons-lightbox')) return;
 
function to_cyrillic(src, output, chunks) {
    if (src == undefined || src == "" || src == null)
         return src;
    if (output == undefined)
        output = new String();
 
    var hash = getConversionHash();
    var location = 0;
    while (location < src.length) {
        var len = Math.min(maxcyrlength, src.length - location);
        var arr = undefined;
        var sub;
        while (len > 0) {
        sub = src.substr(location, len);
        arr = hash[sub];
        if (arr != undefined)
        break;
        else
        len--;
        }
        // need this for translit on the fly
        if (chunks != undefined)
        chunks[chunks.length] = sub;
        if (arr == undefined) {
        output += sub;
        location ++;
        }
        else {


        // case analysis
        var overlay = document.createElement('div');
        var newChar = arr;
        overlay.id = 'commons-lightbox';
        if (sub.toLowerCase() == sub.toUpperCase() && arr.length > 1 && arr[1] && (newChar.toUpperCase() != newChar.toLowerCase())) {
        // need translit hash to determine if previous character (and possibly the one before it)
        // were converted and are in upper case
        // set prevDud to true previous is not a translated character or simply a blank
        // set prevCap to true if previous was translated and was upper case


        var prevCh = output.length == 0 ? null : output.substr(output.length - 1, 1);
        overlay.innerHTML =
        var prevDud = !prevCh || !getTranslitString(prevCh);
            '<div class="clb-backdrop"></div>' +
        var prevCap = (!prevDud && prevCh == prevCh.toUpperCase());
            '<div class="clb-content">' +
                '<button class="clb-prev" aria-label="Previous">‹</button>' +
                '<button class="clb-next" aria-label="Next">›</button>' +
                '<button class="clb-close" aria-label="Close">×</button>' +
                '<img class="clb-image" alt="">' +
                '<div class="clb-caption"></div>' +
            '</div>';


        // sub is caseless but result isn't. case will depend on lookbehind and lookahead
        document.body.appendChild(overlay);
        if (prevDud || !prevCap) {
        output += newChar.toLowerCase();
        prevCap = false;
        }
        else {
        var next = " ";
        if (location + len < src.length)
        next = src.substr(location + len, 1);


        if (next != next.toUpperCase() && next == next.toLowerCase() ) {
        overlay.querySelector('.clb-backdrop').onclick = closeLightbox;
        //next is lowercase (and not caseless)
        overlay.querySelector('.clb-close').onclick = closeLightbox;
        output += newChar.toLowerCase();
        overlay.querySelector('.clb-prev').onclick = showPrev;
        }
        overlay.querySelector('.clb-next').onclick = showNext;
        else if (next == next.toUpperCase() && next != next.toLowerCase() ) {
        // next is uppercase (and not caseless)
        output += newChar.toUpperCase();
        }
        else {
        // next is caseless. output case determined by the case of output[length - 2]
        var pprevCh = output.length == 1 ? null : output.substr(output.length - 2, 1);
        var pprevDud = !pprevCh || !getTranslitString(pprevCh);
        if (!pprevDud && (pprevCh == pprevCh.toUpperCase())) {
        //pre-prev is in upper case. output is also uppercase
        output += newChar.toUpperCase();
        }
        else {
            output += newChar.toLowerCase();
        }
        }
        }
        }
        else if ((sub.toLowerCase() == sub.toUpperCase()) && (arr.length < 2 || !arr[1])) {
        // literal treatment of newChar
        output += newChar;


        }
        document.addEventListener('keydown', function (e) {
        else if (sub != sub.toLowerCase()) {
            if (!overlay.classList.contains('active')) return;
            if (e.key === 'Escape') closeLightbox();
        // sub not all-lowercase
            if (e.key === 'ArrowLeft') showPrev();
        output += newChar.toUpperCase();
            if (e.key === 'ArrowRight') showNext();
        }
         });
        else {
        // sub is lowercase
            output += newChar.toLowerCase();
        }
        location += len;
         }
     }
     }
    return output;
}


    function openLightbox(img) {
        collectGalleryImages();
        currentIndex = galleryImages.indexOf(img);
        if (currentIndex === -1) return;


        createLightbox();
        showImage(currentIndex);


function convertIt(src,converter){
        document.getElementById('commons-lightbox').classList.add('active');
var resultbuffer="";  
        document.body.style.overflow = 'hidden';
    for(var i=0;i<src.length;i++){
    resultbuffer=converter(resultbuffer+src[i]);
     }
     }
        return converter(resultbuffer);


}
    function showImage(index) {
        var overlay = document.getElementById('commons-lightbox');
        var lbImg = overlay.querySelector('.clb-image');
        var caption = overlay.querySelector('.clb-caption');


        var img = galleryImages[index];
        if (!img) return;


        lbImg.src = img.dataset.fullsrc || img.src;
        lbImg.alt = img.alt || '';
        caption.innerHTML = img.dataset.caption || '';


var translitHash = undefined;
        currentIndex = index;
    }


function initTranslit() {
    function showPrev() {
    if (translitHash == undefined) {
        if (currentIndex > 0) showImage(currentIndex - 1);
        translitHash = new Array();
    }


        for (var i = 0; i < conversionHash.length; i++) {
    function showNext() {
        var ch = conversionHash[i][1];
        if (currentIndex < galleryImages.length - 1) {
        // if the translit string is not caseless, convert cyr string to upper case
            showImage(currentIndex + 1);
        // otherwise maintain its case
        if (conversionHash[i][0].toUpperCase() != conversionHash[i][0].toLowerCase())
        ch = ch.toUpperCase();
        if (translitHash[ch] == undefined)
        translitHash[ch] = conversionHash[i][0];
         }
         }
     }
     }
}


 
    function closeLightbox() {
 
         var overlay = document.getElementById('commons-lightbox');
 
         if (!overlay) return;
//-- translit on-the-fly --
         overlay.classList.remove('active');
 
         document.body.style.overflow = '';
function replaceValue(node, value, stepback) {
    if (stepback == undefined)
        stepback = 0;
    if (isExplorer()) {
         var range = document.selection.createRange();
         range.moveStart("character", -stepback);
         range.text = value;
        range.collapse(false);
         range.select();
     }
     }
    else {
        var scrollTop = node.scrollTop;
        var cursorLoc =  node.selectionStart;
        node.value = node.value.substring(0, node.selectionStart - stepback) + value +
                node.value.substring(node.selectionEnd, node.value.length);
        node.scrollTop = scrollTop;
        node.selectionStart = cursorLoc + value.length - stepback;
        node.selectionEnd = cursorLoc + value.length - stepback;
    }
}
// compare positions
function positionIsEqual(other) {
    if (isExplorer())
        return this.position.isEqual(other.position);
    else
        return this.position == other.position;
 
}
function Position(node) {
  if (node.selectionStart != undefined)
    this.position = node.selectionStart;
  else if (document.selection && document.selection.createRange())
    this.position = document.selection.createRange();
   
  this.isEqual = positionIsEqual;
}
function resetState() {
    this.position = new Position(this.node);
    this.transBuffer = "";
    this.cyrBuffer = "";
}
function StateObject(node) {
    this.node = node;
    this.reset = resetState;
    this.cyrBuffer = "";
    this.transBuffer = "";
    this.position = new Position(node);
}


    /* Event delegation (single, correct) */
    document.addEventListener('click', function (e) {
        var img = e.target;
        if (img && img.matches('.commons-gallery-item img')) {
            openLightbox(img);
        }
    });


var stateHash = new Array();
})();


function isExplorer() {
/* ============================================================
  return (document.selection != undefined && document.selection.createRange().isEqual != undefined);
  Editing tools
  ============================================================ */
if (
    mw.config.get('wgAction') === 'edit' ||
    mw.config.get('wgAction') === 'submit' ||
    mw.config.get('wgCanonicalSpecialPageName') === 'Upload'
) {
    mw.loader.load(
        '/index.php?title=മീഡിയവിക്കി:Common.js/edit.js&action=raw&ctype=text/javascript'
    );
}
}


function pressedKey(event) {
/* ============================================================
  if (isExplorer())
  Special characters subset menu
    return event.keyCode;
  ============================================================ */
  else
function addCharSubsetMenu() {
    return event.which;
    if ($('#editpage-specialchars').length > 0) {
}


function transliterateKey(event) {
         var s = parseInt($.cookie('edittoolscharsubset'), 10);
    /*
         if (isNaN(s)) s = 0;
    if ((event.keyCode == 255 && event.charCode > 0) || event.keyCode == 8) {
         return;
    }
    */
   
    if (event == undefined)
        event = window.event;
   
    var node = null;
    if (event.target) {
        node = event.target;
         }
    else if (event.srcElement) {
        node = event.srcElement;
        }
    // initialize state
    var state = stateHash[node];
    if (state == null) {
        state = new StateObject(node);
        stateHash[node] = state;
    }
    if ( (pressedKey(event) > 20) && !event.ctrlKey && !event.altKey && !event.metaKey) {


         var c = String.fromCharCode(pressedKey(event));
         var $menu = $('<select />')
            .attr('id', 'charSubsetControl')
            .css('display', 'inline')
            .change(chooseCharSubset)
            .data('previousSelectedIndex', s)
            .append($('<option />').text('ഫലകങ്ങൾ'))
            .append($('<option />').text('വിക്കിവിന്യാസങ്ങൾ'))
            .append($('<option />').text('അനുമതിപത്രങ്ങൾ'))
            .append($('<option />').text('മലയാളം'))
            .append($('<option />').text('കൊറിയൻ'))
            .append($('<option />').text('ലത്തീൻ'))
            .append($('<option />').text('ഐ.പി.എ.'))
            .append($('<option />').text('പലവക'))
            .append($('<option />').text('അറബി'))
            .append($('<option />').text('ദേവനാഗരി'))
            .append($('<option />').text('ഹിബ്രു'))
            .append($('<option />').text('പഴയ ഇംഗ്ലീഷ്'));


         // process input
         $('#editpage-specialchars').prepend($menu);
        var result = process_translit(state, c);
        $('#charSubsetControl')[0].selectedIndex = s;
        // finish up
        if (c != result.out || result.replace != 0) {
          if (isExplorer())
        event.returnValue = false;
          else
            event.preventDefault();
 
          replaceValue(node, result.out, result.replace);
 
          state.position = new Position(node);


         }
         $('p', '#editpage-specialchars').each(function (index) {
            $(this).css({
                display: index === s ? 'inline' : 'none',
                visibility: index === s ? 'visible' : 'hidden'
            });
        });
     }
     }
}
}


function TranslitResult() {
function chooseCharSubset() {
     this.out = "";
     var selectedIndex = $(this).find(':selected').index();
     this.replace = 0;
     $('p', '#editpage-specialchars').each(function (index) {
        $(this).css({
            display: index === selectedIndex ? 'inline' : 'none',
            visibility: index === selectedIndex ? 'visible' : 'hidden'
        });
    });
    $.cookie('edittoolscharsubset', selectedIndex);
}
}


function process_translit(state, c) {
$(addCharSubsetMenu);
    // reset state if position changed
    if (!state.position.isEqual(new Position(state.node)))
        state.reset();
    var result = new TranslitResult();
    // initial backbuffer. Add to it as characters are converted
    var backbuffer = getBackBuffer(state.node, state.cyrBuffer.length, 2);
    var chunks = new Array();
    state.transBuffer = state.transBuffer+ c


    var str = to_cyrillic(state.cyrBuffer+c, backbuffer, chunks);
/* ============================================================
  Navigation bars
  ============================================================ */
var NavigationBarHide = 'മറയ്ക്കുക';
var NavigationBarShow = 'പ്രദർശിപ്പിക്കുക';
var indexNavigationBar = 0;


    // remove backbuffer from output
window.toggleNavigationBar = function (index, event) {
    str = str.substr(backbuffer.length);
     var NavToggle = document.getElementById('NavToggle' + index);
    result.out = str;
     var NavFrame = document.getElementById('NavFrame' + index);
    /* str is now left alone - it has the output matching contents of chunks and
    if (!NavFrame || !NavToggle) return;
      will be used to reinitialize backbuffers, along with chunks and state.transBuffer
    */
    // get the difference between state.cyrBuffer and output
    for (var i = 0; i < Math.min(state.cyrBuffer.length, result.out.length); i++) {
        if (state.cyrBuffer.substr(i, 1) != result.out.substr(i, 1)) {
        result.replace = state.cyrBuffer.length - i;
        result.out = result.out.substr(i);
        break;
        }
     }
    if (result.replace == 0) {
              if(result.out.length<state.cyrBuffer.length)
        result.replace=state.cyrBuffer.length- result.out.length;
        result.out = result.out.substr(Math.min(state.cyrBuffer.length, result.out.length));
               
                      //    result.out+="\u0008"
                       
    }
    // update state: backbuffer, bufferArray
    if (chunks.length > 0 && chunks[chunks.length - 1] == result.out.substr(result.out.length - 1)) {
        // no convertion took place, reset state
        state.reset();
    }
    else {
        while (state.transBuffer.length > maxcyrlength) {
        state.transBuffer = state.transBuffer.substr(chunks[0].length);
        chunks.shift();
        str = str.substr(1);
        }
        state.cyrBuffer = str;
    }
     return result;
}
 
function getBackBuffer(node, offset, count) {
    if (isExplorer()) { //.tagName.toUpperCase() == "EDITOR") {
        var range = document.selection.createRange();
        range.moveStart("character", -offset);
        var result = range.text.substr(-count);
        if (!result)
        result = "";
        return result;
 
    } else {
        return node.value.substring(0, node.selectionStart - offset).substr(-count);
    }
}


// need this for bookmarklets
     var show = NavToggle.firstChild.data === NavigationBarShow;
function getSelectedNode() {
    NavToggle.firstChild.data = show ? NavigationBarHide : NavigationBarShow;
  if (document.activeElement)
    return document.activeElement;
  else
     if (window.getSelection && window.getSelection() && window.getSelection().rangeCount > 0) {
        var range = window.getSelection().getRangeAt(0);
        if (range.startContainer && range.startContainer.childNodes && range.startContainer.childNodes.length > range.startOffset)
        return range.startContainer.childNodes[range.startOffset]
    }
  return null;
}


function toggleCyrMode() {
     var children = NavFrame.children;
     var node = getSelectedNode();
     for (var i = 0; i < children.length; i++) {
     if (node) {
         if ($(children[i]).hasClass('NavContent') ||
         if (stateHash[node]) {
            $(children[i]).hasClass('NavPic')) {
        if (removeKeyEventListener(node))
            children[i].style.display = show ? 'block' : 'none';
        delete stateHash[node];
        }
        else {
        if (addKeyEventListener(node))
        stateHash[node] = new StateObject(node);
         }
         }
     }
     }
}
     event.preventDefault();
 
};
function addKeyEventListener(node) {
    if (node.addEventListener)
        node.addEventListener("keypress", transliterateKey, false);
    else if (node.attachEvent)
        node.attachEvent("onkeypress", transliterateKey);
    else return false;
    return true;
}
function removeKeyEventListener(node) {
    if (node.removeEventListener)
        node.removeEventListener("keypress", transliterateKey, false);
    else if (node.detachEvent)
        node.detachEvent("onkeypress", transliterateKey);
    else return false;
    return true;
}
 
function getSelectedText() {
    if (isExplorer()) {
        return document.selection.createRange().text;
    }
    else {
        var node = getSelectedNode();
        if (node && node.value && node.selectionStart != undefined && node.selectionEnd != undefined)
        return node.value.substring(node.selectionStart, node.selectionEnd);
    }
     return "";
}
 
 
/* calling functions  */
 
        function addLoadEvent(func) {
           
            if (window.addEventListener)
                window.addEventListener("load", func, false);
            else if (window.attachEvent)
                window.attachEvent("onload", func);
        }
 
        function addTranslit(editForm,textBox) {
            checkrt(editForm); // check for translit support
 
            if (textBox.addEventListener)
                textBox.addEventListener("keypress", processKeys, false);
            else if (textBox.attachEvent)
                textBox.attachEvent("onkeypress", processKeys);
        }
 
        function addTextEvent() {
 
///////
if(lija_getCookie('mlWikiTranslit')!=null && lija_getCookie('mlWikiTranslit')!="") 
              realTime=(lija_getCookie('mlWikiTranslit')=="true")?true:false;
            //////
 
            var editForm =document.getElementById('editform');
            if(editForm != null) {
                var textBox=document.getElementById('wpTextbox1');
                var textSummary = document.getElementById('wpSummary');
                addTranslit(editForm,textBox);
                addCheckbox(editForm,textBox );
                if(textSummary) { addTranslit(editForm,textSummary); }
            }
 
            // add transliteration feature to search form also
            var searchForm = document.getElementById('searchform');
            if( searchForm != null ) {
try {
var searchBox = document.getElementById('searchInput');
// add IME checkbox control to searchForm
if (searchBox != null || searchForm != null) {
var element = document.createElement("input");
element.setAttribute("type","checkbox");
element.setAttribute("id","sbrealtime");
if (element.addEventListener)
element.addEventListener("click", rtClick, false);
else if (element.attachEvent)
element.attachEvent("onclick", rtClick);
// var labelcheckBox = document.createTextNode('മലയാളത്തിലെഴുതുക');
var chkSpan = document.createElement("span");
chkSpan.setAttribute("id","spnRealtime");
var searchBody = document.getElementById('searchBody');
searchBody.appendChild(element);
searchBody.appendChild(chkSpan);
// searchForm.insertBefore(element,searchBox);
document.getElementById("sbrealtime").checked = realTime;
document.getElementById('spnRealtime').innerHTML = '<a href="http://ml.wikipedia.org/wiki/സഹായം:ടൈപ്പിംഗ്‌" title="Switches keyboard between Malayalam and English">മലയാളത്തിലെഴുതുക</a>';
// searchForm.insertBefore(chkSpan,searchBox);
// var p = document.createElement("p");
// p.setAttribute("style","width:100%;height:1px;");
// searchForm.insertBefore(p,searchBox);
}
}
catch(ex)
{
  //എററിനെ ഓടിക്കുക.
}
if(searchBox) { addTranslit(searchForm,searchBox); }
}           
            //മലയാളം ടൈപ്പിങ് താളുകളിൽ സാധ്യമാക്കാനുള്ള സ്ക്രിപ്റ്റുകൾ  | scripts to avail Malayalam transliteration
            //തിരയല്‍ താള്‍ | Search page


            var simpleSearchForm = document.getElementById('search');
mw.hook('wikipage.content').add(function ($content) {
            if( simpleSearchForm != null) {  
    $content.find('div.NavFrame').each(function () {
              var simpleSearchBox = document.getElementById('searchText');
        indexNavigationBar++;
              if( simpleSearchBox ) { addTranslit(simpleSearchForm, simpleSearchBox );}
        var NavFrame = this;
            }
        var NavHead = $(NavFrame).find('.NavHead').first();
        if (!NavHead.length) return;


            var powerSearchForm = document.getElementById('powersearch');
        var NavToggle = $('<a href="#" class="NavToggle"></a>')
             if( powerSearchForm != null) {
            .attr('id', 'NavToggle' + indexNavigationBar)
              var powerSearchBox = document.getElementById('powerSearchText');
             .text(NavigationBarHide)
              if( powerSearchBox ) { addTranslit(powerSearchForm, powerSearchBox );}
            .on('click', function (e) {
             }  
                toggleNavigationBar(indexNavigationBar, e);
             });


            // തലക്കെട്ട് മാറ്റല്‍ താള്‍. | Move page
        NavFrame.id = 'NavFrame' + indexNavigationBar;
        NavHead.append(NavToggle);
    });
});


            var movePageForm = document.getElementById('movepage');
/* ============================================================
            if( movePageForm != null ) {
  Collapsible tables
                var newTitleBox = document.getElementById('wpNewTitle');
  ============================================================ */
                if( newTitleBox ) {addTranslit(movePageForm, newTitleBox);}
var autoCollapse = 2;
                var reasonBox = document.getElementById('wpReason');
var collapseCaption = 'മറയ്ക്കുക';
                if( reasonBox ) {addTranslit(movePageForm, reasonBox ); }
var expandCaption = 'പ്രദർശിപ്പിക്കുക';
                         
            }


              //വിക്കിപീഡിയ:കളരി
function collapseTable(tableIndex) {
                      var kalariForm = document.getElementById('createbox');
    var Button = document.getElementById('collapseButton' + tableIndex);
            if( kalariForm != null ) {
    var Table = document.getElementById('collapsibleTable' + tableIndex);
    if (!Table || !Button) return;


                var kalariText = document.getElementsByName('title')[0];
    var Rows = Table.rows;
                if( kalariText ) {addTranslit(kalariForm, kalariText);}
    var hide = Button.firstChild.data === collapseCaption;
                }


            //അപ്‌ലോഡ് താള്‍
    for (var i = 1; i < Rows.length; i++) {
            //********************
        Rows[i].style.display = hide ? 'none' : '';
            var upForm=document.getElementById('mw-upload-form');
            if(upForm)//ഈ ഫോം ഇല്ലെങ്കില്‍ പിന്നെ മുന്നോട്ട് പോകണ്ട.
            {
              var upName=document.getElementById('wpDestFile');
              var upComment=document.getElementById('wpUploadDescription');
              if(upName) addTranslit(upForm,upName);
              if(upComment) addTranslit(upForm,upComment);
            }
          //**************     
     }
     }
       
     Button.firstChild.data = hide ? expandCaption : collapseCaption;
     function addCheckbox(editform,textBox) {
}
 
 
            if(editform==null||textBox==null) return;
 
                  try
                    {
            var element = document.createElement("input");
            element.setAttribute("type","checkbox");
            element.setAttribute("id","realtime");
 
            if (element.addEventListener)
                element.addEventListener("click", rtClick, false);
            else if (element.attachEvent)
                element.attachEvent("onclick", rtClick);
 
            var labelcheckBox = document.createTextNode(' മലയാളം എഴുതുവാന്‍ ഈ ഉപാധി സ്വീകരിക്കുക - Use Ctrl + M to Toggle.');
            editform.insertBefore(element,textBox);
            document.getElementById("realtime").checked = realTime;
            editform.insertBefore(labelcheckBox,textBox);
            var p = document.createElement("p");
            p.setAttribute("style","width:100%;height:1px;");
            editform.insertBefore(p,textBox);
            }
            catch(ex)
            {
              //എററിനെ ഓടിക്കുക.
            }
        }
 
        var imeStatus = false;
       
        function processKeys(event) {
            if (rtsupported) {
                e = event || window.event;
 
                var myKeyCode = 0;
                var myShiftKey = false;
                if( document.all ) { //IE
                    myKeycode = e.keyCode;
                    myShiftKey = e.shiftKey;
                } else if ( document.getElementById || document.layers ) {
                    myKeyCode = e.which;
                    myShiftKey = (myKeyCode == 16)?true:false;
                }
               
 
                if ((e.keyCode == 13 && e.ctrlKey) || (e.which == 109 && e.ctrlKey))
            {
            realTime = !realTime;
lija_setCookie('mlWikiTranslit',realTime,1);//save in cookie
var chk = document.getElementById('realtime');
var chkSb = document.getElementById('sbrealtime');
if (chk) { chk.checked = realTime; }
if (chkSb) { chkSb.checked = realTime; }
                return false;
            }
           
            else if ((e.keyCode >= 3328 && e.keyCode <= 3455) || (e.which >= 3328 && e.which <= 3455)) {
                var chk = document.getElementById('realtime');
var spanSb = document.getElementById('spnRealtime');
var chkSb = document.getElementById('sbrealtime');
                if (imeStatus == false || realTime) {
                    realTime = false;
    if (chk) { chk.checked = realTime; chkSb.checked = realTime; spanSb.innerText = chkSb.checked }
    imeStatus = true;
  //alert('A Malayalam input tool was detected. Disabling in-built transliteration. To turn it On again use Ctrl+M');
window.status='A Malayalam input tool was detected. Disabling in-built transliteration. To turn it On again use Ctrl+M';//FF failure
    // return false;
}
            }
                           
                else if (realTime) {
                    imeStatus = false;
                    transliterateKey(event); // call transliteration function
                }
            }
        }
        var realTime=false;
 
        function rtClick(event) {
                      realTime = !realTime;
                      lija_setCookie('mlWikiTranslit',realTime,1);//save in cookie
        }
 
        var rtsupported = false;
        var error;
 
        function checkrt(editform) {
            try {
       
            /*
            var nav = navigator.userAgent.toUpperCase();
            rtsupported = (nav.indexOf("GECKO") >= 0 || nav.indexOf("OPERA") >= 0 || nav.indexOf("SAFARI") >= 0);
            */
       
                rtsupported = (document.selection != undefined)
       
                if (!rtsupported) {
                var element = document.createElement("TEXTAREA");
                editform.appendChild(element);
       
                if (element.selectionStart != undefined)
                rtsupported = true;
                editform.removeChild(element);
                }
       
            } catch (error) {}
        }
 
//************************************
// ട്രാന്‍സ്‌ലിറ്ററേഷന്‍ സ്ക്രിപ്റ്റില്‍ കൂക്കി സപ്പോര്‍ട്ട് ചേര്‍ക്കാനുള്ള ശ്രമം


function lija_getCookie(cookieName)
$(function () {
{
    var tableIndex = 0;
if (document.cookie.length>0)
    $('table.collapsible').each(function () {
{
        var $table = $(this);
cookieStart=document.cookie.indexOf(cookieName + "=");
        var $header = $table.find('tr:first th:first');
if (cookieStart!=-1)
        if (!$header.length) return;
{  
cookieStart=cookieStart + cookieName.length+1;
cookieEnd=document.cookie.indexOf(";",cookieStart);
if (cookieEnd==-1) cookieEnd=document.cookie.length;
return unescape(document.cookie.substring(cookieStart,cookieEnd));
}
}
return "";
}


function lija_setCookie(cookieName,value,expiredays)
        $table.attr('id', 'collapsibleTable' + tableIndex);
{
var exdate=new Date();
exdate.setDate(exdate.getDate()+expiredays);
document.cookie=cookieName+ "=" +escape(value)+"; path=/"+
((expiredays==null) ? "" : "; expires="+exdate.toGMTString());
}


//************************************
        var $button = $('<span class="collapseButton">[</span>');
        var $link = $('<a href="#"></a>')
            .attr('id', 'collapseButton' + tableIndex)
            .text(collapseCaption)
            .on('click', function (e) {
                e.preventDefault();
                collapseTable(tableIndex);
            });


// add this line to your monobook.js to disable in-built transliteration - thanks to Sadik Khalid for this quick tip
        $button.append($link).append(']');
// var userIMEEnabled = false;   // paste this line to user monobook.js and remove // from the begining of this line
        $header.prepend($button);


// check for user preference and load in-built transliteration tool
        tableIndex++;
  if(typeof(window.userIMEEnabled) == 'undefined') { addLoadEvent(addTextEvent); }
    });
});
/*
</pre></nowiki>
*/
"https://schoolwiki.in/മീഡിയവിക്കി:Common.js" എന്ന താളിൽനിന്ന് ശേഖരിച്ചത്