MediaWiki:Gadget-markadmins.js: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
No edit summary |
||
(8 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
// rewritten by [[m:User:Hoo man]]; 2012-08-26, adapted by [[User:Obersachse]], optimized by [[User:Jack who built the house]] | // rewritten by [[m:User:Hoo man]]; 2012-08-26, adapted by [[User:Obersachse]], optimized by [[User:Jack who built the house]] | ||
// For attribution: [[MediaWiki:Gadget-markadmins.js]] | |||
(function () { | (function () { | ||
var userSet; | var userSet; | ||
var userSetTips = { | var userSetTips = { | ||
'A' : 'administrator', | 'A' : 'administrator', | ||
'B' : ' | 'B' : 'bureaucrat', | ||
' | 'CU' : 'checkuser', | ||
' | 'IA' : 'interface administrator', | ||
'S' : ' | 'IWA' : 'interwiki administrator', | ||
'SA':' | 'NSS': 'non-steward suppressor', | ||
'OS': 'suppressor', | |||
'S' : 'steward', | |||
'SA': 'system administrator', | |||
'AF': 'abuse filter administrator' | |||
}; | }; | ||
Line 31: | Line 34: | ||
); | ); | ||
} | } | ||
var $links = $content.find('a[title^="User"], a[title^="Talk"]'); | var $links = $content.find('a[title^="User"], a[title^="Talk"]'); | ||
if (runNum === 2) { | if (runNum === 2) { | ||
if ($links.length === prevLinksCount) { | if ($links.length === prevLinksCount) { | ||
Line 53: | Line 54: | ||
} | } | ||
new mw.Api().get({ | |||
action: 'query', | |||
list: 'allusers', | |||
}).done(function (ans) { | augroup: 'sysop|bureaucrat|checkuser|interface-admin|abusefilter-admin|interwiki-admin|non-stewardsuppress|suppress|steward|sysadmin', | ||
userSet = | auprop: 'groups', | ||
aulimit: 500, | |||
format: 'json', | |||
formatversion: 2 | |||
}).done(function(ans) { | |||
var list = ans.query.allusers, | |||
groups = ['sysop', 'bureaucrat', 'checkuser', 'interface-admin', 'interwiki-admin', 'non-stewardsuppress', 'suppress', 'steward', 'sysadmin', 'abusefilter-admin'], | |||
key = ['A', 'B', 'CU', 'IA', 'IWA', 'NSS', 'OS', 'S', 'SA', 'AF'], | |||
userSet = {}; | |||
for (var i = 0; i < key.length; i++) { | |||
userSet[key[i]] = []; | |||
} | |||
for (var i = 0; i < list.length; i++) { | |||
for (var j = 0; j < groups.length; j++) { | |||
if (list[i].groups.includes(groups[j])) { | |||
userSet[key[j]].push(list[i].name); | |||
} | |||
} | |||
} | |||
$links.each(function (i, link) { | $links.each(function (i, link) { | ||
if (!link.parentNode || | if (!link.parentNode || | ||
Line 70: | Line 91: | ||
matches = /^User:(.+)|Talk:(.+)/.exec(link.title); | matches = /^User:(.+)|Talk:(.+)/.exec(link.title); | ||
if (!matches) return; | if (!matches) return; | ||
if | if (matches[2]) { | ||
if ($(link).parent().hasClass('mw-usertoollinks') || link.textContent.match(/обс/i)) return; | if ($(link).parent().hasClass('mw-usertoollinks') || link.textContent.match(/обс/i)) return; | ||
matches[1] = matches[2]; | matches[1] = matches[2]; | ||
Line 77: | Line 97: | ||
return; | return; | ||
} | } | ||
user = decodeURIComponent(matches[1]); | user = decodeURIComponent(matches[1]); | ||
if (link.href.indexOf('redlink=1') !== -1) { | if (link.href.indexOf('redlink=1') !== -1) { | ||
user = user.replace(/ \([^\)]+\)$/, ''); | user = user.replace(/ \([^\)]+\)$/, ''); | ||
} | } | ||
for (flag in userSet) { | for (flag in userSet) { | ||
if (userSet[flag].indexOf(user) !== -1 && userSetTips[flag]) { | if (userSet[flag].indexOf(user) !== -1 && userSetTips[flag]) { | ||
Line 90: | Line 110: | ||
} | } | ||
if (!flags.length) return; | if (!flags.length) return; | ||
tips = ' (' + tips.join(', ') + ')'; | tips = ' (' + tips.join(', ') + ')'; | ||
var spanElem = document.createElement('span'); | var spanElem = document.createElement('span'); |
Latest revision as of 09:27, 20 May 2024
// rewritten by [[m:User:Hoo man]]; 2012-08-26, adapted by [[User:Obersachse]], optimized by [[User:Jack who built the house]]
// For attribution: [[MediaWiki:Gadget-markadmins.js]]
(function () {
var userSet;
var userSetTips = {
'A' : 'administrator',
'B' : 'bureaucrat',
'CU' : 'checkuser',
'IA' : 'interface administrator',
'IWA' : 'interwiki administrator',
'NSS': 'non-steward suppressor',
'OS': 'suppressor',
'S' : 'steward',
'SA': 'system administrator',
'AF': 'abuse filter administrator'
};
function addCSS(css) {
var styleElem = document.createElement('style');
styleElem.appendChild(document.createTextNode(css));
document.getElementsByTagName('head')[0].appendChild(styleElem);
}
function markadmins($content) {
if (!$content.length) return;
runNum++;
if (runNum === 1) {
addCSS(
'tt.userflags { color:#0645ad; }' +
'.userflags-wrapper { -moz-user-select:none; }' +
'.userflags-none { display: none; }'
);
}
var $links = $content.find('a[title^="User"], a[title^="Talk"]');
if (runNum === 2) {
if ($links.length === prevLinksCount) {
return;
} else {
if ($links.length > prevLinksCount) {
$links = $links.slice(prevLinksCount);
} else {
var msg = 'MediaWiki:Gadget-markadmins.js: Нестандартная ситуация: количество ссылок на втором проходе (' + $links.length + ') меньше, чем на первом (' + prevLinksCount + '). Снова обходим все ссылки.';
if (console.info) {
console.info(msg);
} else {
console.log(msg);
}
}
}
}
new mw.Api().get({
action: 'query',
list: 'allusers',
augroup: 'sysop|bureaucrat|checkuser|interface-admin|abusefilter-admin|interwiki-admin|non-stewardsuppress|suppress|steward|sysadmin',
auprop: 'groups',
aulimit: 500,
format: 'json',
formatversion: 2
}).done(function(ans) {
var list = ans.query.allusers,
groups = ['sysop', 'bureaucrat', 'checkuser', 'interface-admin', 'interwiki-admin', 'non-stewardsuppress', 'suppress', 'steward', 'sysadmin', 'abusefilter-admin'],
key = ['A', 'B', 'CU', 'IA', 'IWA', 'NSS', 'OS', 'S', 'SA', 'AF'],
userSet = {};
for (var i = 0; i < key.length; i++) {
userSet[key[i]] = [];
}
for (var i = 0; i < list.length; i++) {
for (var j = 0; j < groups.length; j++) {
if (list[i].groups.includes(groups[j])) {
userSet[key[j]].push(list[i].name);
}
}
}
$links.each(function (i, link) {
if (!link.parentNode ||
(/[?#]/.test(link.href) && link.href.indexOf('redlink=1') === -1) ||
(link.parentElement && link.parentElement.className === 'cancelLink')
) {
return;
}
var matches, user, flags = [], tips = [], flag;
matches = /^User:(.+)|Talk:(.+)/.exec(link.title);
if (!matches) return;
if (matches[2]) {
if ($(link).parent().hasClass('mw-usertoollinks') || link.textContent.match(/обс/i)) return;
matches[1] = matches[2];
} else if (!matches[1]) {
return;
}
user = decodeURIComponent(matches[1]);
if (link.href.indexOf('redlink=1') !== -1) {
user = user.replace(/ \([^\)]+\)$/, '');
}
for (flag in userSet) {
if (userSet[flag].indexOf(user) !== -1 && userSetTips[flag]) {
flags.push(flag);
tips.push(userSetTips[flag]);
}
}
if (!flags.length) return;
tips = ' (' + tips.join(', ') + ')';
var spanElem = document.createElement('span');
spanElem.className = 'userflags-wrapper';
var nbspElem = document.createTextNode('\u00A0');
var ttElem = document.createElement('tt');
ttElem.className = 'userflags';
ttElem.title = tips;
var flagsElem = document.createTextNode('(' + flags.join(',') + ')');
ttElem.appendChild(flagsElem);
spanElem.appendChild(nbspElem);
spanElem.appendChild(ttElem);
link.parentNode.insertBefore(spanElem, link.nextSibling);
link.title = link.title + tips;
});
});
prevLinksCount = $links.length;
}
var runNum = 0;
var prevLinksCount;
markadmins($('#mw-content-text'));
mw.hook('wikipage.content').add(markadmins);
}());