MediaWiki:Common.js: Różnice pomiędzy wersjami

Z Nonsensopedii, polskiej encyklopedii humoru
M
Linia 27: Linia 27:
}
}
$(zipForum);
$(zipForum);

/*
Informacje o zabezpieczeniu (typu: "Strona zabezpieczona przed edytowaniem, półzabezpieczona przed przeniesieniem")
…chyba nie działa.
*/
function Zab() {
if (mw.config.get('wgRestrictionEdit')[0] === undefined && mw.config.get('wgRestrictionMove')[0] === undefined) return;
var zabezpieczenie = '';
var editRestriction = 'brak';
var moveRestriction = "brak";
if (mw.config.get('wgRestrictionEdit')[0] !== undefined) editRestriction = mw.config.get('wgRestrictionEdit')[0];
if (mw.config.get('wgRestrictionMove')[0] !== undefined) moveRestriction = mw.config.get('wgRestrictionMove')[0];
var klucz = {autoconfirmed: "półzabezpieczona", sysop: "zabezpieczona"};
if (editRestriction == moveRestriction) {
zabezpieczenie = klucz[editRestriction];
} else {
if (editRestriction != 'brak') {
zabezpieczenie += klucz[editRestriction] + " przed edycją";
if (moveRestriction != "brak") zabezpieczenie += ", ";
}
if (moveRestriction != 'brak') {
zabezpieczenie += klucz[moveRestriction] + " przed przeniesieniem";
}
}
$("<span class='restr'>Strona " + zabezpieczenie + ".</span>").css({
float: "right"
}).appendTo("#contentSub");
}
if (mw.config.get('wgRestrictionEdit') !== null && mw.config.get('wgRestrictionMove') !== null) jQuery(document).ready(Zab);


/**
/**

Wersja z 11:01, 19 cze 2020

/* <pre><nowiki> */
/** COMMON.JS **
 * Plik zawiera funkcje używane w innych skryptach. Edytuj ostrożnie!
**/

/** UWAGI Z LIPCA 2019 **
 * Ten plik jest stosunkowo krótki, ale jeśli cokolwiek się zepsuje, pamiętaj, PAMIĘTAJ, aby sprawdzić gadżety.
 * Lista gadżetów dostępna jest tutaj: [[MediaWiki:Gadgets-definition]]. Jeśli o tym nie wiedziałeś, to nie ruszaj – pewnie i tak nie zrozumiesz co jest od czego.
 * Common.js NIE działa na skórce mobilnej. Jeśli coś ma działać na skórce mobilnej, masz dwa wyjścia:
 ** albo wrzucić do do MediaWiki:Mobile.js (lub na jednego usera (np do testów) do Użytkownik:Nazwa/Minerva.js – ja też nie wiem czemu tak), nie będzie wtedy działać na desktopowych
 ** albo – zalecana opcja, zwłaszcza jak ma działać i na desktopie, i na mobilce – dać do gadżetu.
 * a, i jak robisz coś zwławszcza dla mobilnej, to ograniczaj doładowywanie rzeczy typu mw.loader.load, bo niby spowalnia ładowanie.
**/

/* Archiwizacja Porum – ten brzydki komunikat nad wątkiem */
function zipForum() {
    if (!("Forum" != mw.config.get('wgCanonicalNamespace') || "view" != mw.config.get("wgAction") || "Strona główna" == mw.config.get("wgTitle")))
        if (!document.getElementById("naglowekforum") || document.getElementById("nieodkopuj")) {
        	var groups = mw.config.get('wgUserGroups');
        	if (groups.indexOf("bot") == -1 && groups.indexOf("content-moderator") == -1 && groups.indexOf("sysop") == -1) {
	            $("#ca-edit a")
    	        .css("color", "DarkKhaki")
        	    .attr("href", "")
            	.attr("title", "Ten wątek jest archiwalny, prosimy o nieedytowanie go.");
        	}
        }
}
$(zipForum);

/**
 * Skrypt dla Szablon:Galeria
 * Źródło: [[wikipedia:pl:MediaWiki:Common.js]]
 */
function toggleImage (group, remindex, shwindex) {
	jQuery("#ImageGroupsGr" + group + "Im" + remindex).hide();
	jQuery("#ImageGroupsGr" + group + "Im" + shwindex).show();
}
function ImageGroup() {
	if (mw.config.values.skin === "minerva") return;	//nie powinno się ładować na mobilce
	jQuery('div.ImageGroup').each(function(i, group) {
		var unitnode = jQuery('div.ImageGroupUnits', group).get(0);
		if (unitnode === undefined) {
			return 1;
		}
		var units = jQuery(unitnode).children('.center');
		var count = units.get().length;
		if (count <= 1) {
			return 1;
		}
		units.each(function(j, currentimage) {
			jQuery(currentimage).attr('id', "ImageGroupsGr" + i + "Im" + j);
			var leftlink = jQuery('<a href="#"/>');
			if (j !== 0) {
				leftlink.text('◀').click(function() {
					toggleImage(i, j, j - 1); return false;
				});
			}
			var rightlink = jQuery('<a href="#"/>');
			if (j != count - 1) {
				rightlink.text('▶').click(function() {
					toggleImage(i, j, j + 1); return false;
				});
			}
			jQuery('<div/>').css({ 'font-size' : '110%', 'font-weight' : 'bold' })
				.addClass('disabled-user-selection')
				.append(leftlink)
				.append('<tt>(' + (j + 1) + '/' + count +  ')</tt>')
				.append(rightlink)
				.prependTo(jQuery(currentimage));
			if (j !== 0) {
				jQuery(currentimage).hide().addClass('noprint');
			}
		});
	});
}
$(ImageGroup);
/* </pre></nowiki> */