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

No edit summary
No edit summary
വരി 1: വരി 1:
/* mw.loader.load('//en.wikipedia.org/w/index.php?title=User:Joeytje50/JWB.js/load.js&action=raw&ctype=text/javascript');
/* ============================================================
*/
  OpenStreetMap marker URL fix
 
  ============================================================ */
window.onload = function () {
mw.hook('wikipage.content').add(function () {
    // Find all image elements on the page
     var images = document.querySelectorAll('img');
     var images = document.querySelectorAll('img');
    // Loop through the images and modify the `src` if it matches the criteria
     for (var i = 0; i < images.length; i++) {
     for (var i = 0; i < images.length; i++) {
         var img = images[i];
         var img = images[i];
          
         if (img.src &&
        // Check if the `src` starts with the specified URL
            img.src.indexOf('https://tile.openstreetmap.org/v4/marker/') === 0) {
        if (img.src.startsWith("https://tile.openstreetmap.org/v4/marker/")) {
             img.src = img.src.replace(
             // Replace the `src` with the desired URL
                'https://tile.openstreetmap.org/v4/marker/',
            var newSrc = img.src.replace("https://tile.openstreetmap.org/v4/marker/", "https://maps.wikimedia.org/v4/marker/");
                'https://maps.wikimedia.org/v4/marker/'
             img.src = newSrc;
             );
 
         }
         }
     }
     }
};
});


//Load images from Wikimedia commons using template
mw.loader.using(['mediawiki.util']).then(function () {


  function loadCommonsImages() {
/* ============================================================
    const elements = document.querySelectorAll('.commons-image');
  Load images from Wikimedia Commons using template
  ============================================================ */
mw.hook('wikipage.content').add(function ($content) {


     elements.forEach(function (el) {
     $content.find('.commons-image').each(function () {
      const filename = el.dataset.filename;
        var el = this;
      if (!filename) return;
        var filename = el.dataset.filename;
        if (!filename) return;


      const width = el.dataset.width || 300;
        var width = el.dataset.width || 300;
      const align = el.dataset.align || 'none';
        var align = el.dataset.align || 'none';
      const caption = el.dataset.caption || '';
        var caption = el.dataset.caption || '';


      const apiUrl =
        var apiUrl =
        'https://commons.wikimedia.org/w/api.php' +
            'https://commons.wikimedia.org/w/api.php' +
        '?action=query' +
            '?action=query' +
        '&format=json' +
            '&format=json' +
        '&prop=imageinfo' +
            '&prop=imageinfo' +
        '&iiprop=url|extmetadata' +
            '&iiprop=url|extmetadata' +
        '&iiurlwidth=' + width +
            '&iiurlwidth=' + width +
        '&titles=File:' + encodeURIComponent(filename) +
            '&titles=File:' + encodeURIComponent(filename) +
        '&origin=*';
            '&origin=*';


      fetch(apiUrl)
        fetch(apiUrl)
        .then(response => response.json())
            .then(function (r) { return r.json(); })
        .then(data => {
            .then(function (data) {
          const pages = data.query.query.pages;
          const page = Object.values(pages)[0];


          if (!page.imageinfo) {
                if (!data.query || !data.query.pages) {
            el.textContent = 'Image not found on Wikimedia Commons';
                    el.textContent = 'Error loading image';
            return;
                    return;
          }
                }


          const info = page.imageinfo[0];
                var pages = data.query.pages;
          const imgUrl = info.thumburl || info.url;
                var page = pages[Object.keys(pages)[0]];
          const artist =
            info.extmetadata?.Artist?.value || 'Unknown';
          const license =
            info.extmetadata?.LicenseShortName?.value || '';
          const licenseUrl =
            info.extmetadata?.LicenseUrl?.value || '';


          const figure = document.createElement('figure');
                if (!page.imageinfo) {
          figure.style.maxWidth = width + 'px';
                    el.textContent = 'Image not found on Wikimedia Commons';
                    return;
                }


          if (align === 'right') figure.style.float = 'right';
                var info = page.imageinfo[0];
          if (align === 'left') figure.style.float = 'left';
                var imgUrl = info.thumburl || info.url;
          if (align === 'center') figure.style.margin = 'auto';


          const img = document.createElement('img');
                var artist = 'Unknown';
          img.src = imgUrl;
                var license = '';
          img.alt = caption || filename;
                var licenseUrl = '';
          img.loading = 'lazy';
          img.style.width = '100%';


          figure.appendChild(img);
                if (info.extmetadata) {
                    if (info.extmetadata.Artist) {
                        artist = info.extmetadata.Artist.value;
                    }
                    if (info.extmetadata.LicenseShortName) {
                        license = info.extmetadata.LicenseShortName.value;
                    }
                    if (info.extmetadata.LicenseUrl) {
                        licenseUrl = info.extmetadata.LicenseUrl.value;
                    }
                }


          if (caption || license) {
                var figure = document.createElement('figure');
            const figcaption = document.createElement('figcaption');
                figure.style.maxWidth = width + 'px';
            figcaption.style.fontSize = '0.8em';
            figcaption.style.textAlign = 'center';


            figcaption.innerHTML =
                if (align === 'right') figure.style.float = 'right';
              caption +
                if (align === 'left') figure.style.float = 'left';
              '<br>' +
                if (align === 'center') {
              '© ' + artist +
                    figure.style.marginLeft = 'auto';
              (licenseUrl
                    figure.style.marginRight = 'auto';
                ? ' – <a href="' + licenseUrl + '" target="_blank">' +
                }
                  license +
                  '</a>'
                : '');


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


          el.replaceWith(figure);
                figure.appendChild(img);
        })
 
        .catch(() => {
                if (caption || license) {
          el.textContent = 'Error loading image from Wikimedia Commons';
                    var figcaption = document.createElement('figcaption');
        });
                    figcaption.style.fontSize = '0.8em';
                    figcaption.style.textAlign = 'center';
 
                    figcaption.innerHTML =
                        caption +
                        '<br>© ' + artist +
                        (licenseUrl
                            ? ' – <a href="' + licenseUrl +
                              '" target="_blank">' + license + '</a>'
                            : '');
 
                    figure.appendChild(figcaption);
                }
 
                el.replaceWith(figure);
            })
            .catch(function () {
                el.textContent = 'Error loading image from Wikimedia Commons';
            });
     });
     });
  }
});


  if (document.readyState === 'loading') {
    document.addEventListener('DOMContentLoaded', loadCommonsImages);
  } else {
    loadCommonsImages();
  }


});
/* ============================================================
  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'
    );
}




//Quick Edit Box
/* ============================================================
// [[User:BrandonXLF/QuickEdit.js]]
  Special characters subset menu
//mw.loader.load('https://en.wikipedia.org/w/index.php?title=User:BrandonXLF/QuickEdit.js&action=raw&ctype=text/javascript');
  ============================================================ */
//mw.loader.load( '/index.php?title=മീഡിയവിക്കി:Common.js/QuickEdit.js&action=raw&ctype=text/javascript' );
function addCharSubsetMenu() {
    if ($('#editpage-specialchars').length > 0) {


/*ടൂൾബാറിൽ അവലംബം ചേർക്കാനുള്ള സൗകര്യം കൂട്ടിച്ചേർക്കുന്നതിനായി */
        var s = parseInt($.cookie('edittoolscharsubset'), 10);
if ( mw.config.get( 'wgAction' ) === 'edit' || mw.config.get( 'wgAction' ) === 'submit' || mw.config.get( 'wgCanonicalSpecialPageName' ) === 'Upload' ) {
        if (isNaN(s)) s = 0;
    /* scripts specific to editing pages */
/*    importScript( 'മീഡിയവിക്കി:Common.js/edit.js' ); */
    mw.loader.load( '/index.php?title=മീഡിയവിക്കി:Common.js/edit.js&action=raw&ctype=text/javascript' );
}


        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('പഴയ ഇംഗ്ലീഷ്'));


/*
        $('#editpage-specialchars').prepend($menu);
==addCharSubsetMenu==
        $('#charSubsetControl')[0].selectedIndex = s;
*/


/* add menu for selecting subsets of secial characters  */
        $('p', '#editpage-specialchars').each(function (index) {
/***** must match MediaWiki:Edittools *****/
            $(this).css({
function addCharSubsetMenu() {
                display: index === s ? 'inline' : 'none',
if($('#editpage-specialchars').length>0) {
                visibility: index === s ? 'visible' : 'hidden'
/* default subset from cookie */
            });
var s = parseInt( $.cookie('edittoolscharsubset') );
        });
if ( isNaN(s) ) s = 0;
    }
var $menu = $('<select />')
.attr('id', 'charSubsetControl')
.css('display', 'inline');
$menu.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('പഴയ ഇംഗ്ലീഷ്'));
$('#editpage-specialchars').prepend($menu);
/* update dropdown control to value of cookie */
$('#charSubsetControl')[0].selectedIndex = s;
$('p', '#editpage-specialchars').each(function(index) {
if(index==s) {
$(this).css('display', 'inline');
$(this).css('visibility', 'visible');
} else {
$(this).css('display', 'none');
$(this).css('visibility', 'hidden');
}
});
}
}
}


/*
===chooseCharSubsetMenu===
*/
/* select subsection of special characters */
function chooseCharSubset() {
function chooseCharSubset() {
var selectedIndex = $(this).find(':selected').index();
    var selectedIndex = $(this).find(':selected').index();
$('p', '#editpage-specialchars').each(function(index) {
    $('p', '#editpage-specialchars').each(function (index) {
if(index==selectedIndex) {
        $(this).css({
$(this).css('display', 'inline');
            display: index === selectedIndex ? 'inline' : 'none',
$(this).css('visibility', 'visible');
            visibility: index === selectedIndex ? 'visible' : 'hidden'
}else {
        });
$(this).css('display', 'none');
    });
$(this).css('visibility', 'hidden');
    $.cookie('edittoolscharsubset', selectedIndex);
}
});
$.cookie('edittoolscharsubset', selectedIndex);
$(this).data('previousSelectedIndex', selectedIndex);
}
}


/*
$(addCharSubsetMenu);
== customizeWikipedia ==
*/


function customizeWikipedia() {
addCharSubsetMenu();
}
$(customizeWikipedia);


/**
/* ============================================================
* Dynamic Navigation Bars (experimental)
  Navigation bars
*
  ============================================================ */
* Description: See [[Wikipedia:NavFrame]].
* Maintainers: UNMAINTAINED
*/
 
/* set up the words in your language */
var NavigationBarHide = 'മറയ്ക്കുക';
var NavigationBarHide = 'മറയ്ക്കുക';
var NavigationBarShow = 'പ്രദർശിപ്പിക്കുക';
var NavigationBarShow = 'പ്രദർശിപ്പിക്കുക';
var indexNavigationBar = 0;
var indexNavigationBar = 0;


/**
window.toggleNavigationBar = function (index, event) {
* Shows and hides content and picture (if available) of navigation bars
     var NavToggle = document.getElementById('NavToggle' + index);
* Parameters:
     var NavFrame = document.getElementById('NavFrame' + index);
*    indexNavigationBar: the index of navigation bar to be toggled
     if (!NavFrame || !NavToggle) return;
**/
window.toggleNavigationBar = function ( indexNavigationBar, event ) {
     var NavToggle = document.getElementById( 'NavToggle' + indexNavigationBar );
     var NavFrame = document.getElementById( 'NavFrame' + indexNavigationBar );
    var NavChild;
 
     if ( !NavFrame || !NavToggle ) {
        return false;
    }


     /* if shown now */
     var show = NavToggle.firstChild.data === NavigationBarShow;
    if ( NavToggle.firstChild.data === NavigationBarHide ) {
     NavToggle.firstChild.data = show ? NavigationBarHide : NavigationBarShow;
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
                NavChild.style.display = 'none';
            }
        }
     NavToggle.firstChild.data = NavigationBarShow;


     /* if hidden now */
     var children = NavFrame.children;
     } else if ( NavToggle.firstChild.data === NavigationBarShow ) {
     for (var i = 0; i < children.length; i++) {
        for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
        if ($(children[i]).hasClass('NavContent') ||
            if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) {
            $(children[i]).hasClass('NavPic')) {
                NavChild.style.display = 'block';
            children[i].style.display = show ? 'block' : 'none';
            }
         }
         }
        NavToggle.firstChild.data = NavigationBarHide;
     }
     }
     event.preventDefault();
     event.preventDefault();
};
};


/* adds show/hide-button to navigation bars */
mw.hook('wikipage.content').add(function ($content) {
function createNavigationBarToggleButton( $content ) {
     $content.find('div.NavFrame').each(function () {
     var NavChild;
         indexNavigationBar++;
    /* iterate over all < div >-elements */
        var NavFrame = this;
    var $divs = $content.find( 'div' );
         var NavHead = $(NavFrame).find('.NavHead').first();
    $divs.each( function ( i, NavFrame ) {
        if (!NavHead.length) return;
         /* if found a navigation bar */
         if ( $( NavFrame ).hasClass( 'NavFrame' ) ) {


            indexNavigationBar++;
        var NavToggle = $('<a href="#" class="NavToggle"></a>')
            var NavToggle = document.createElement( 'a' );
             .attr('id', 'NavToggle' + indexNavigationBar)
            NavToggle.className = 'NavToggle';
             .text(NavigationBarHide)
             NavToggle.setAttribute( 'id', 'NavToggle' + indexNavigationBar );
             .on('click', function (e) {
             NavToggle.setAttribute( 'href', '#' );
                toggleNavigationBar(indexNavigationBar, e);
             $( NavToggle ).on( 'click', $.proxy( window.toggleNavigationBar, window, indexNavigationBar ) );
            });


            var isCollapsed = $( NavFrame ).hasClass( 'collapsed' );
        NavFrame.id = 'NavFrame' + indexNavigationBar;
            /**
        NavHead.append(NavToggle);
            * Check if any children are already hidden.  This loop is here for backwards compatibility:
     });
            * the old way of making NavFrames start out collapsed was to manually add style="display:none"
});
            * to all the NavPic/NavContent elements.  Since this was bad for accessibility (no way to make
            * the content visible without JavaScript support), the new recommended way is to add the class
            * "collapsed" to the NavFrame itself, just like with collapsible tables.
            */
            for ( NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling ) {
                if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) {
                    if ( NavChild.style.display === 'none' ) {
                        isCollapsed = true;
                    }
                }
            }
            if ( isCollapsed ) {
                for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) {
                    if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) {
                        NavChild.style.display = 'none';
                    }
                }
            }
            var NavToggleText = document.createTextNode( isCollapsed ? NavigationBarShow : 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 ( $( NavFrame.childNodes[j] ).hasClass( 'NavHead' ) ) {
                    NavToggle.style.color = NavFrame.childNodes[j].style.color;
                    NavFrame.childNodes[j].appendChild( NavToggle );
                }
            }
            NavFrame.setAttribute( 'id', 'NavFrame' + indexNavigationBar );
        }
     } );
}
 
mw.hook( 'wikipage.content' ).add( createNavigationBarToggleButton );


/*END OF NAVIGATION BARS*/


/** Collapsible tables *********************************************************
/* ============================================================
*
  Collapsible tables
*  Description: Allows tables to be collapsed, showing only the header. See
  ============================================================ */
*              [[Wikipedia:NavFrame]].
*  Maintainers: [[User:R. Koot]]
*/
var autoCollapse = 2;
var autoCollapse = 2;
var collapseCaption = "മറയ്ക്കുക";
var collapseCaption = "മറയ്ക്കുക";
var expandCaption = "പ്രദർശിപ്പിക്കുക";
var expandCaption = "പ്രദർശിപ്പിക്കുക";
 
function collapseTable( tableIndex )
function collapseTable(tableIndex) {
{
    var Button = document.getElementById("collapseButton" + tableIndex);
var Button = document.getElementById( "collapseButton" + tableIndex );
    var Table = document.getElementById("collapsibleTable" + tableIndex);
var Table = document.getElementById( "collapsibleTable" + tableIndex );
    if (!Table || !Button) return;
 
if ( !Table || !Button ) {
    var Rows = Table.rows;
return false;
    var hide = Button.firstChild.data === collapseCaption;
}
 
    for (var i = 1; i < Rows.length; i++) {
var Rows = Table.rows;
        Rows[i].style.display = hide ? "none" : "";
    }
if ( Button.firstChild.data == collapseCaption ) {
    Button.firstChild.data = hide ? expandCaption : 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()
$(function () {
{
    var tableIndex = 0;
var tableIndex = 0;
    $('table.collapsible').each(function () {
var NavigationBoxes = new Object();
        var $table = $(this);
var Tables = document.getElementsByTagName( "table" );
        var $header = $table.find('tr:first th:first');
        if (!$header.length) return;
for ( var i = 0; i < Tables.length; i++ ) {
 
if ( $(Tables[i]).hasClass( "collapsible" ) ) {
        $table.attr('id', 'collapsibleTable' + tableIndex);
 
/* only add button and increment count if there is a header row to work with */
        var $button = $('<span class="collapseButton">[</span>');
var HeaderRow = Tables[i].getElementsByTagName( "tr" )[0];
        var $link = $('<a href="#"></a>')
if (!HeaderRow) continue;
            .attr('id', 'collapseButton' + tableIndex)
var Header = HeaderRow.getElementsByTagName( "th" )[0];
            .text(collapseCaption)
if (!Header) continue;
            .on('click', function (e) {
                e.preventDefault();
NavigationBoxes[ tableIndex ] = Tables[i];
                collapseTable(tableIndex);
Tables[i].setAttribute( "id", "collapsibleTable" + tableIndex );
            });
 
var Button    = document.createElement( "span" );
        $button.append($link).append(']');
var ButtonLink = document.createElement( "a" );
        $header.prepend($button);
var ButtonText = document.createTextNode( collapseCaption );
 
        tableIndex++;
Button.className = "collapseButton"//Styles are declared in 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 ( $(NavigationBoxes[i]).hasClass( "collapsed" ) || ( tableIndex >= autoCollapse && $(NavigationBoxes[i]).hasClass( "autocollapse" ) ) ) {
collapseTable( i );
}
else if ( $(NavigationBoxes[i]).hasClass( "innercollapse" ) ) {
var element = NavigationBoxes[i];
while (element = element.parentNode) {
if ( $(element).hasClass( "outercollapse" ) ) {
collapseTable ( i );
break;
}
}
}
}
}
$( createCollapseButtons );
"https://schoolwiki.in/മീഡിയവിക്കി:Common.js" എന്ന താളിൽനിന്ന് ശേഖരിച്ചത്