MediaWiki:Common.js
Revision as of 08:56, 24 June 2021 by NileshValanki (talk | contribs)
Note: After publishing, you may have to bypass your browser's cache to see the changes.
- Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
- Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
- Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
- Opera: Press Ctrl-F5.
$( function(){
if( mw.config.get('wgIsMainPage') ){
$('#firstHeading').remove();
}
if( mw.config.get('wgPageName').split( '/' ).length > 1 ){
var tempPageName = mw.config.get('wgPageName').split( '/' )[0];
var tempLink ='< <a href="https://wiki.ekatrafoundation.org/wiki/' + tempPageName + '">' + tempPageName.replaceAll("_", " ") + '</a>';
$("#top").after( $( '<p>').css( 'font-size', '17px').html( tempLink ) );
}
if( mw.config.get('wgUserName') === null ){
$('body').bind('cut copy', function(e) {
e.preventDefault();
});
} else {
$("#content").removeAttr("onmousedown");
$("#content").removeAttr("onselectstart");
mw.loader.load( '/index.php?title=MediaWiki:OCR.js&action=raw&ctype=text/javascript');
}
});
$( function(){
var sidebarCategory = $("#p-Categories > .vector-menu-content");
var sidebarAuthor = $("#p-Authors > .vector-menu-content");
sidebarCategory.empty();
sidebarAuthor.empty();
mw.loader.using( [ 'mediawiki.api' ], function(){
var sel1 = $('<select>').css( 'width', '100%').appendTo( sidebarCategory );
var sel2 = $('<select>').css( 'width', '100%').appendTo( sidebarAuthor );
sel1.append( $("<option>").attr('disabled', true).attr('selected', true).text( "-- Select an option --" ) );
sel2.append( $("<option>").attr('disabled', true).attr('selected', true).text( "-- Select an option --" ) );
// For category Categories
catMemberParam1 = {
"action": "query",
"format": "json",
"list": "categorymembers",
"cmtitle": "Category:Categories on EkatraWiki",
"cmprop": "title",
"cmtype": "subcat",
"cmlimit": "500"
};
(new mw.Api()).get( catMemberParam1, { async: false } ).done(function ( resData ){
var catOptions = [];
var members = resData.query.categorymembers;
// Creating MenuItems array from Category Members
members.forEach( function(it){
var ct = it.title.replace("Category:", "");
sel1.append( $("<option>").attr('value', ct).text(ct) );
});
sel1.on('change', function (e) {
var valueSelected = this.value;
window.location = "https://wiki.ekatrafoundation.org/wiki/Category:" + valueSelected;
});
});
// For category Author
catMemberParam2 = {
"action": "query",
"format": "json",
"list": "categorymembers",
"cmtitle": "Category:Authors on EkatraWiki",
"cmprop": "title",
"cmtype": "subcat",
"cmlimit": "500"
};
(new mw.Api()).get( catMemberParam2, { async: false } ).done(function ( resData ){
var catOptions = [];
var members = resData.query.categorymembers;
// Creating MenuItems array from Category Members
members.forEach( function(it){
var ct = it.title.replace("Category:", "");
sel2.append( $("<option>").attr('value', ct).text(ct) );
});
sel2.on('change', function (e) {
var valueSelected = this.value;
window.location = "https://wiki.ekatrafoundation.org/wiki/Category:" + valueSelected;
});
});
} );
});
$( function(){
var countPoem2 = $(".Poem2-Ekatra");
if( countPoem2.length > 0 ){
var Poem2lenghtArray = [0,1];
Poem2lenghtArray.forEach(function(j) {
var poemElement = $(".Poem2-Ekatra").eq(j);
if( poemElement.length ){
var poemText = poemElement.html();
var poemArray = poemText.split("\n");
poemElement.text("");
// First measure
poemArray.forEach( function(i) {
poemElement.append( '<p style="text-indent: 2em;">' + i + '</p>' );
});
// Second measure
poemElement.children('p').each(function () {
$(this).css('text-indent', '2em');
});
}
});
}
});
$( function(){
// toggled by toggle button. also determines which toggle button image to use
var useCustom = false;
// toggleImgs[0] to switch to custom, toggleImgs[1] to revert to default
var toggleImgs = [
'//storage.googleapis.com/material-icons/external-assets/v4/icons/svg/ic_search_black_24px.svg',
'//storage.googleapis.com/material-icons/external-assets/v4/icons/svg/ic_youtube_searched_for_black_24px.svg'
];
var zoomInImg = '//storage.googleapis.com/material-icons/external-assets/v4/icons/svg/ic_zoom_in_black_24px.svg';
var zoomOutImg = '//storage.googleapis.com/material-icons/external-assets/v4/icons/svg/ic_zoom_out_black_24px.svg';
// create DOM elements
$('#content').prepend('<div id="zoomButtons">\
<img id="zoomInIcon" src="' + zoomInImg + '" alt="zoom in"">\
<img id="zoomOutIcon" src="' + zoomOutImg + '" alt="zoom out"">\
<img id="toggleButton" src="' + toggleImgs[+ useCustom] +
'" alt="toggle zoom"> </div>');
$('#zoomButtons').css({'float': 'right'});
// find DOM elements used later
var $bodyContent = $('.mw-body-content');
var $toggleButton = $('#toggleButton');
// sizes[0] is default, sizes[1] is custom
var sizes = [parseFloat($('.mw-body-content').css('font-size'))];
// default custom zoom of 2
sizes[1] = sizes[0] + 2;
// the + converts bool to 0 or 1 to use as array index
function updateSize() {
$bodyContent.css({'font-size':(sizes[+ useCustom] + 'pt')});
}
function toggle() {
useCustom = !useCustom;
$toggleButton.attr('src',toggleImgs[+ useCustom]);
updateSize();
}
function zoom(dif) {
sizes[1] += dif;
if (useCustom) {
updateSize();
} else {
toggle();
}
}
$( '#zoomInIcon' ).on( 'click', function(){
zoom(1);
});
$( '#zoomOutIcon' ).on( 'click', function(){
zoom(-1);
});
$( '#toggleButton' ).on( 'click', toggle );
});
/**
* Convert numbers between numeral systems.
*
* Dependencies: jquery.cookie, mediawiki.util, mediawiki.user
* Source: https://www.mediawiki.org/wiki/MediaWiki:Gadget-Numerakri.js
* Revision: 2019-01-11
*
* @copyright 2012 Daniel Friesen
* @copyright 2012 Siddhartha Ghai
* @copyright 2014 Bhawani Gautam
* @copyright 2012-2018 Timo Tijhof
* @license <https://opensource.org/licenses/MIT>
*/
/*jshint browser:true, unused:true, forin:false */
/*global $, mw */
(function () {
'use strict';
var msgs = {
'option-default': {
en: 'Default',
bho: 'डिफ़ॉल्ट',
gu: 'ડિફોલ્ટ',
hi: 'डिफ़ॉल्ट',
ne: 'डिफल्ट',
pa: 'ਅਸਲ ਦਿੱਖ',
sa: 'उत्सर्गः'
},
'option-arabic': {
en: '1 2 3'
},
'option-devanagari': {
en: 'Devanagari',
bho: '१२३',
hi: '१२३',
ne: '१२३',
sa: '१२३'
},
'option-gujarati': {
en: '૧ ૨ ૩',
gu: '૧ ૨ ૩'
},
'option-gurmukhi': {
en: 'Gurmukhi',
pa: '੧੨੩'
},
'label-url': {
en: '//www.mediawiki.org/wiki/MediaWiki_talk:Gadget-Numerakri.js',
gu: '//gu.wikipedia.org/wiki/વિકિસૂક્તિઃઅંક_પરિવર્તક',
hi: '//hi.wikipedia.org/wiki/विकिपीडिया:अंक_परिवर्तक',
ne: '//ne.wikipedia.org/wiki/विकिपीडिया:अंक_परिवर्तक',
pa: '//pa.wikipedia.org/wiki/ਵਿਕੀਪੀਡੀਆ:ਅੰਕ ਬਦਲੋ',
sa: '//sa.wikipedia.org/wiki/विकिपीडिया:अङ्कपरिवर्तकम्'
},
'label-text': {
en: 'Convert numerals',
bho: 'अंक बदलाव',
gu: 'અંક પરિવર્તક',
hi: 'अंक परिवर्तन',
ne: 'अंक परिवर्तन',
pa: 'ਅੰਕ ਬਦਲੋ',
sa: 'अङ्कपरिवर्तकम्'
},
'label-tooltip': {
en: 'Convert between Arabic and Devanagari numerals',
bho: 'नागरी आ अरबी अंकों में अदला-बदली करीं',
gu: 'ગુજરાતી અને અંગ્રેજી અંકોમાં પરિવર્તન કરો',
hi: 'नागरी और अरबी अंकों में परिवर्तन करें',
ne: 'देवनागरी र अरबी अंकहरूमा परिवर्तन गर्नुहोस्',
pa: 'ਅੰਕਾਂ ਨੂ ਗੁਰਮੁਖੀ ਤੇ ਅਰਬੀ ਵਿਚ ਬਦਲੇਂ',
sa: 'देवनागरी-अरबी-अङ्कयोः चयनं करोतु'
}
},
maps = {
arabic: ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'],
devanagari: ['०', '१', '२', '३', '४', '५', '६', '७', '८', '९'],
gujarati: ['૦', '૧', '૨', '૩', '૪', '૫', '૬', '૭', '૮', '૯'],
gurmukhi: ['੦', '੧', '੨', '੩', '੪', '੫', '੬', '੭', '੮', '੯']
},
availableMaps,
currentType = 'default',
matchers = {},
walker,
styleTag;
function isValidType(type) {
return type === 'default' || availableMaps.indexOf(type) !== -1;
}
/** @return {Object.<RegExp>} */
function getMatchers(targetType) {
var rChars;
if (!matchers[targetType]) {
rChars = { 0: [], 1: [], 2: [], 3: [], 4: [], 5: [], 6: [], 7: [], 8: [], 9: [] };
$.each(maps, function (type, map) {
if (type !== targetType) {
for (var i = 0; i <= 9; i++) {
rChars[i].push(map[i]);
}
}
});
$.each(rChars, function (num, chars) {
rChars[num] = new RegExp('(' + chars.map(mw.RegExp.escape).join('|') + ')', 'g');
});
matchers[targetType] = rChars;
}
return matchers[targetType];
}
function msg(key) {
return msgs[key][mw.config.get('wgUserLanguage')] || msgs[key].en;
}
/**
* @param {HTMLElement|TextNode} node
* @return {number} NodeFilter.FILTER_* constant
*/
function filterNode(node) {
if (node.nodeType === Node.TEXT_NODE) {
return NodeFilter.FILTER_ACCEPT;
}
var n = node.nodeName && node.nodeName.toLowerCase();
if (n === 'input' || n === 'textarea' || $(node).hasClass('mw-numerakri-skip')) {
// Skip this element and skip its children
return NodeFilter.FILTER_REJECT;
}
// Skip this element, but check its children
return NodeFilter.FILTER_SKIP;
}
/**
* @param {TextNode} node
*/
function handleTextNode(node) {
var original = node.nodeValue,
changed = original,
matchers = getMatchers(currentType),
i = 0;
for (; i <= 9; i++) {
changed = changed.replace(matchers[i], maps[currentType][i]);
}
if (original !== changed) {
node.nodeValue = changed;
}
}
// https://doc.wikimedia.org/mediawiki-core/master/js/#!/api/mw-method-requestIdleCallback
function idleWalker(deadline) {
var el;
if (!walker) {
return;
}
while (deadline.timeRemaining() > 0) {
el = walker.nextNode();
if (!el) {
// Reached the end
walker = null;
return;
}
handleTextNode(el);
}
// The user may interact with the page. We pause so the browser can process
// interaction. The text handler will continue after that.
if (walker) {
mw.requestIdleCallback(idleWalker);
}
}
/**
* Save a browser cookie for 30 days, or remove it.
* @param {string|null} value
*/
function saveType(value) {
mw.requestIdleCallback(function () {
$.cookie('mw-numerakri-type', value, { expires: 30, path: '/' });
});
}
/**
* @return {string}
*/
function getStoredType() {
var value = $.cookie('mw-numerakri-type');
if (value !== null && !isValidType(value)) {
// Remove bad cookie
saveType(null);
value = null;
}
return value || 'default';
}
function startPageConversion() {
if (styleTag) {
// Undo style for a previously selected type
$(styleTag).remove();
styleTag = null;
}
if (currentType === 'default') {
// Don't change the page
return;
}
if (currentType === 'arabic') {
styleTag = mw.loader.addStyleTag('.mw-parser-output ol, ol.references, li.references { list-style-type: decimal; }');
} else if (currentType === 'devanagari') {
styleTag = mw.loader.addStyleTag('.mw-parser-output ol, ol.references, li.references { list-style-type: devanagari; }');
}
// If a walker is already active, replace it.
// If no walker is active yet, start it.
if (!walker) {
mw.requestIdleCallback(idleWalker);
}
walker = document.createTreeWalker(document.body, NodeFilter.SHOW_ALL, filterNode, false);
}
/** @return {HTMLElement} */
function createSelector() {
var $select = $('<select>').addClass('mw-numerakri-skip').append(
$('<option>').val('default').text(msg('option-default'))
);
availableMaps.forEach(function (type) {
$select.append($('<option>').val(type).text(msg('option-' + type)));
});
$select.val(currentType);
$select.on('change', function () {
currentType = this.value;
startPageConversion();
saveType(currentType);
});
return $select[0];
}
function init() {
var potlet, menu;
// Decide which types to show
availableMaps = ['gujarati', 'arabic'];
// Decide selected type
currentType = getStoredType();
startPageConversion();
potlet = mw.util.addPortletLink(
'p-personal',
msg('label-url'),
msg('label-text'),
'pt-numconvert',
msg('label-tooltip'),
null,
mw.user.isAnon() ? '#pt-createaccount' : '#pt-userpage'
);
menu = $('<div>').addClass('mw-numerakri-menu').append(createSelector())[0];
if(potlet) {
potlet.appendChild(menu);
}
}
$(function () {
mw.requestIdleCallback(init);
});
}());